harbor blobs占用的空间越来越大的情况记录和解决办法

harbor blobs占用的空间越来越大的情况记录和解决办法


2019-08-07

harbor所在的服务器突然提示磁盘空间不足,上去查看磁盘占用情况发现,/data竟然达到了49GB:


导致磁盘剩余只有17GB



于是我就好奇,做了一个统计,看看当前harbor中的所有image加起来到底是多少,这一统计就发现了问题,一共加起来才用了10GB不到,咋占用磁盘空间就达到了49GB呢?


所以怀疑,是否是产生了垃圾,导致了磁盘空间没有释放!!!


于是查了一下解决办法:

执行如下的前提是必须保证harbor是处于stop状态,而不能是down状态:

先执行:

docker-compose stop


然后执行

dockerrun -it --name gc --rm--volumes-from registryvmware/registry-photon:v2.6.2-v1.5.0garbage-collect--dry-run /etc/registry/config.yml


如果harbor是down状态,则会报错:

docker: Error responsefrom daemon: No such container: registry.


检测出如下结果:


此时磁盘占用情况为:


然后执行:

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


可以看到上述并没有起作用:



于是在harbor控制台上手动删除了一些image,然后查看磁盘是没有立即释放的。

于是又执行了一次垃圾回收:

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


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



然后查看发现,磁盘空间确实释放了2GB:


此时的磁盘空间占用为:



最后再启动harbor:docker-compose start


这只是证明了垃圾回收针对删除的image是起作用的。但是为啥blobs会占用这么大的空间呢?

于是接着查找原因,终于发现了一篇文章中记录着解决办法:

文章链接:https://www.cnblogs.com/xzkzzz/p/10151482.html

Harbor删除镜像后且GC清理后,磁盘空间没有释放。因为我们push大量相同标签的镜像,Docker 镜像由标签引用,并由唯一的摘要标识。这意味着如果myImage使用标记推送两个图像,在DR内部他们显示的不同,它们将由两个不同的digests标识。最后推送的Images是当前的。Docker 镜像由layers组成,每个layers都关联一个blob。该blob是最占用存储的文件; 这些文件将由GC清理。正由上面的描述每个镜像都会存储一个引用,因为,我们重复提交10次,那一个标签在DR中会有10个引用,标签只能获取tag。而其他9个只能用digest获取了。

简单的来说就是因为相同的标签的镜像重复提交次数过多导致。


通过向docker-compose.yml中添加:

ports:

  -127.0.0.1:5000:5000


然后通过执行(需提前下载mortensrasmussen/docker-registry-manifest-cleanup):

docker run--network="host" -it -v /data/registry:/registry -eREGISTRY_URL=http://127.0.0.1:5000mortensrasmussen/docker-registry-manifest-cleanup


来清理已删除未使用的那些blobs!!!


执行结果如下:


此时查看服务器磁盘空间,已经释放了:


可以看到,磁盘占用的情况已经发生了变化:


这简直是太美妙了!问题终于解决了!很久之前,在虚拟机中使用harbor,时间长了就出现过一回这个情况,但是当时没有找到解决办法,最后无奈迁移了harbor中的数据到新的harbor中。但是当时就对harbor的这个情况印象深刻,终于在这个环境中再次出现了,并且终于解决了!又攻克了一道大山!!!




补充一下通过harbor清理垃圾的方法:

首先必须以admin用户登录才行,普通用户是看不到以下页面的:


以上只是逻辑上的清理,但是磁盘空间并没有释放,必须要执行如下命令才能释放空间:

docker run -it --name gc --rm

--volumes-from registry vmware/registry-photon:v2.6.2-v1.5.0 garbage-collect

/etc/registry/config.yml


但是以上命令不能删除多余的layer,只能释放删除的image的资源。若想真正删除多余的layer,还是需要:mortensrasmussen/docker-registry-manifest-cleanup 出马才行!!!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 201,924评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,781评论 2 378
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,813评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,264评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,273评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,383评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,800评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,482评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,673评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,497评论 2 318
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,545评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,240评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,802评论 3 304
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,866评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,101评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,673评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,245评论 2 341

推荐阅读更多精彩内容

  • 此文档需要在docker安装完成之后操作 安装docker-compose curl方式 python-pip安装...
    杨家小七阅读 6,216评论 2 3
  • harbor官方下载地址: https://github.com/vmware/harbor/releases 配...
    酒馆_1916阅读 842评论 3 2
  • Harbor是一个用于存储和分发Docker镜像的企业级Registry服务器,通过添加一些企业必需的功能特性,例...
    大鹏之动阅读 6,435评论 0 2
  • Harbor简介 Harbor是一个用于存储和分发Docker镜像的企业级Registry服务器,通过添加一些企业...
    SetZero阅读 3,333评论 3 6
  • 今天醒来第一次4:37,想着早起打卡快到了,就坚持到5;00睡觉。 第二次7:33,收了能量继续睡。 第三次8:0...
    我和遥遥阅读 134评论 0 1