`
m635674608
  • 浏览: 5030998 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

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"



http://www.jianshu.com/p/6ca10427ad77

https://segmentfault.com/a/1190000009175004

 

分享到:
评论

相关推荐

    docker清理大杀器/docker的overlay、overlay2文件占用磁盘太大的解决办法

    本文讲述了如何解决 Docker 中的 overlay 和 overlay2 文件占用磁盘太大的问题,并提供了相应的解决方案。同时,文章也附带了 Docker 配置 overlay 存储驱动的前提条件和步骤。 一、 Docker 中的 overlay 和 ...

    离线一键部署、卸载docker

    离线一键部署与卸载Docker是针对网络环境有限或者不稳定情况下的解决方案,它使得用户无需连接到互联网就能完成Docker的安装与移除过程。本文将详细介绍如何使用提供的资源来实现这一目标。 首先,我们需要了解...

    详解Docker源码编译安装

    解决方案:移除devicemapper文件夹,例如:`mv /var/lib/docker/devicemapper/ .` 3. **make build出错**:在执行`make build`时,可能会遇到因软件包依赖问题导致的错误。这通常需要根据错误提示手动安装缺少的...

    盘点汇总Docker磁盘环境的清理方法.docx

    盘点汇总Docker磁盘环境的清理方法.docx

    docker 离线安装 for redhat 6.5

    3. **更新YUM缓存**:运行`yum clean all`来清理YUM的缓存,然后使用`yum makecache`创建新的缓存,这样YUM就可以找到新添加的Docker仓库。 4. **安装Docker**:现在你可以通过YUM安装Docker了。运行`yum install ...

    Docker学习视频(讲师马永亮)10集之第6集:存储卷

    9. **卷插件**:Docker还支持卷插件,允许用户使用第三方存储解决方案(如NFS、Ceph、GlusterFS等)来扩展Docker的存储能力,满足更复杂的企业级存储需求。 10. **最佳实践**:在实际应用中,应尽量避免在容器的 `/...

    docker容器中crontab无法正常运行解决方案

    Crontab是一个在Unix系统中用于定时执行任务的工具,通常被用于运行定期任务如备份、清理日志等。Docker容器化技术允许我们将应用打包并运行在隔离的环境中,这使得它变得非常流行。然而,将Crontab运行在Docker容器...

    Docker容器日志查看与清理的方法(亲测有效)

    在Docker环境中,管理和清理日志对于保持系统稳定性和优化磁盘使用至关重要。本文将详细介绍如何查看和清理Docker容器日志,以及如何通过配置来限制日志的大小,从而达到“治本”的目的。 首先,当我们遇到Docker...

    docker.service启动失败:Unit not found的原因及解决办法

    如果问题确实是由于缺少docker.socket文件,还有另外两种解决方案: 1. 卸载Docker,然后重新安装。这个操作能够重新创建需要的docker.socket文件。 2. 创建一个新的/usr/lib/systemd/system/docker.socket文件,并...

    Docker日志太多导致磁盘占满的处理方法

    Docker容器在启动/重启的时候会往 /var/lib/docker 中写东西,如果你在启动docker容器遇到 No space left on device 的问题,可以按照下面的步骤进行清理相关的日志操作。 1、 对 /var/lib/docker/containers 下的...

    完美解决在docker容器中启动tomcat始终报端口被占用的错误

    总之,遇到Docker中Tomcat启动报端口被占用的错误时,首先要检查和清理占用端口的进程,然后通过端口映射或修改配置文件来避免未来的冲突。记住,良好的容器和端口管理是维持Docker环境稳定运行的关键。

    docker-fpm-wrapper:Docker FPM包装器

    【描述】 Docker FPM Wrapper 是一个专为在Docker容器中高效运行PHP-FPM应用设计的解决方案。它着重于日志记录、Prometheus监控以及在Kubernetes(K8s)环境中的优雅关闭功能,以确保服务的稳定性和性能。此项目特别...

    在Centos7中安装Docker1.12的详细教程

    Docker 1.12 版本相较于之前的 1.9 版本引入了许多新特性,比如增强的网络功能和 Swarm 集群管理,这些改进使得 Docker 成为了更强大的容器化解决方案。以下是在 CentOS 7 上安装 Docker 1.12 的详细步骤: 首先,...

    lovely-pytest-docker:Pytest插件提供使用docker-compose服务作为治具的功能

    1. **启动和停止docker-compose服务**:在测试开始前,插件会自动启动docker-compose文件中定义的服务,并在测试结束后清理这些服务,确保测试环境的独立性。 2. **服务绑定到测试函数**:通过pytest标记,我们可以...

    ELK-docker:具有Curator和Beats数据托运人支持的ELK监视堆栈的Docker配置

    这个配置为日志管理和分析提供了灵活且高效的解决方案,尤其适用于分布式系统和云环境。 1. **Elasticsearch**: - **Elasticsearch** 是一个开源的分布式搜索引擎,以其实时性、可扩展性和高性能而闻名。它支持...

    sitecore-docker-examples-2

    用于创建自定义Sitecore图像的示例解决方案,具有用于容器开发的推荐文件夹结构(请参阅custom-images )。 用于基于容器的Sitecore实例准备( init.ps1 )和清理( clean.ps1 )的示例PowerShell脚本。 Docker...

    Kubernetes常见问题排查与解决方案.docx

    解决方案:可以清理磁盘释放资源,或者通过修改 Kubelet 的配置参数 imagefs.available 来提高阈值,然后重启 Kubelet。 六、kubectl 查看日志时提示: Error from server: Get ...

    集群规模下日志处理和网络层的经验分享.pdf

    2. 使用Docker日志API远程重定向:虽然可以避免磁盘占用问题,但仍然需要Agent来清理日志,可能引入运维复杂度,并需要处理重连时的日志回溯。 3. 容器内进程直接管理日志:这会降低系统的透明性和控制性,且可能...

Global site tag (gtag.js) - Google Analytics