1.在使用Jenkins发版操做时发现,推送私有仓库harbor报错:redis
received unexpected HTTP status: 500 Internal Server Errordocker
2.想要登录harbor查看,发现harbor界面登录报错:登录校验失败服务器
3.登录服务器,查看harbor的日志,在redis.log中找到报错信息spa
提示磁盘爆满日志
4.登录ranchar,发现rancher也挂掉了,执行:docker ps -a |grep ranchar ,拿到ranchar的容器id,执行:docker logs --tail=200 ranchar容器id 查看ranchar的日志code
当时忘了截图了。。blog
总之也提示磁盘已满内存
5.查看磁盘使用状况,执行:df -hit
发现/home目录已满console
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已经能够登陆,上传镜像发版也没有问题了