站长资讯网
最全最丰富的资讯网站

docker清理方案解析

我们在使用docker的过程中发现基于swarm使用Storage Driver: overlay的方式进行存储.但是发现这个特别占用存储空间.

清理所有停止的容器

  docker container prune   

清理所有不用数据(停止的容器,不使用的volume,不使用的networks,悬挂的镜像)

  docker system prune -a  

overlay存储

我们通过上面的操作清除了一些无用的数据,但是,overlay还是特别大.我们先了解下overlay存储.

overlayfs

集成进了linux 3.18内核.
overlay存储驱动主要使用的是overlayfs技术.中文名是叠合式文件系统.多个文件系统可以mount之后进行合并.
docker 镜像层 lowerdir
docker 容器层 upperdir
docker 容器挂载点 merged

这个三个层对应了 overlayFs的结构. 我们通过docker inspect 可以查看到如下结构

  "GraphDriver": {              "Name": "overlay",              "Data": {                  "LowerDir": "/mnt/docker/overlay/5eb97eb91bed89a9c879142900419ad118215af05c291989282c130d031d7019/root",                  "MergedDir": "/mnt/docker/overlay/454f70c61de03ce2a517d7e2ea8c19e319a95cd2275d8b826f4244071315e513/merged",                  "UpperDir": "/mnt/docker/overlay/454f70c61de03ce2a517d7e2ea8c19e319a95cd2275d8b826f4244071315e513/upper",                  "WorkDir": "/mnt/docker/overlay/454f70c61de03ce2a517d7e2ea8c19e319a95cd2275d8b826f4244071315e513/work"              }          }  

镜像在 /root
挂载点在 /merged
容器在 /upper
工作目录 /work

overlayfs数据清理

我们做了一个实验,我们启动一个容器(版本不同),之后

  docker stop conatiner  docker rm container  

通过对数据大小的监控,我们发现 overlay会随着新镜像的产生而产生一些数据,随着容器的关闭删除,这个文件并没有缩小体积.如何解决呢 看来我们忽视了一个问题.我们使用 docker system prune以为可以不需要的数据都清理了,但是关于images中是这样描述的" dangling images" 悬挂的镜像 .关于这个词汇我还没有理解.不过通过测试,即使我把容器停止也无法清理镜像,所以,我无法理解 悬挂是怎样的状态.

  docker rmi images  

最后我们通过手动删除镜像,则之前产生的overlay数据就随之减少了.

tips:
查看overlay 大小 du –max-depth=1 -h
查看数量 ls|wc -w

整理

镜像有新版本产生的话,我们可以按照这样的流程操作

  docker stop container  docker rm container  docker rmi image  docker pull image  docker run ...  

这样就避免了系统磁盘一眨眼的时间就满了.

其他

docker 时间同步

  ln -snf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo Asia/Shanghai > /etc/timezone  

docker 存储地方修改

  ExecStart=/usr/bin/dockerd --graph="/mnt/data/images"

赞(0)
分享到: 更多 (0)
网站地图   沪ICP备18035694号-2    沪公网安备31011702889846号