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 查看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/yechen2019/p/11577564.html