[转]harbor磁盘爆满,执行垃圾回收清理镜像

 

1.在使用Jenkins发版操作时发现,推送私有仓库harbor报错:

received unexpected HTTP status: 500 Internal Server Error

2.想要登陆harbor查看,发现harbor界面登陆报错:登陆校验失败

3.登陆服务器,查看harbor的日志,在redis.log中找到报错信息

 提示磁盘爆满

4.登陆ranchar,发现rancher也挂掉了,执行:docker ps -a |grep ranchar ,拿到ranchar的容器id,执行:docker logs --tail=200 ranchar容器id 查看ranchar的日志

当时忘了截图了。。

总之也提示磁盘已满

5.查看磁盘使用情况,执行:df -h

 发现/home目录已满

6.进入home目录下,执行:du -hs *| sort -h,发现harbor占比最大,然后一路找下去,发现是harbor的/registry/docker/registry 占比最大

至此,已能判断出是harbor的镜像占用内存过大,导致磁盘爆满

7.停止harbor,防止在删除镜像过程中有人在上传镜像,导致镜像的图层不全

docker-compose stop

8.预览运行效果

docker run -it --name gc --rm --volumes-from registry vmware/registry:2.6.2-photon garbage-collect --dry-run /etc/registry/config.yml

9.删除相关文件和镜像

docker run -it --name gc --rm --volumes-from registry vmware/registry:2.6.2-photon garbage-collect  /etc/registry/config.yml

10.启动harbor

docker-compose start

至此,harbor已经可以登录,上传镜像发版也没有问题了

原文地址:https://www.cnblogs.com/zhangrui153169/p/13398804.html