我们在使用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 中的 overlay 和 overlay2 文件占用磁盘太大的问题,并提供了相应的解决方案。同时,文章也附带了 Docker 配置 overlay 存储驱动的前提条件和步骤。 一、 Docker 中的 overlay 和 ...
离线一键部署与卸载Docker是针对网络环境有限或者不稳定情况下的解决方案,它使得用户无需连接到互联网就能完成Docker的安装与移除过程。本文将详细介绍如何使用提供的资源来实现这一目标。 首先,我们需要了解...
解决方案:移除devicemapper文件夹,例如:`mv /var/lib/docker/devicemapper/ .` 3. **make build出错**:在执行`make build`时,可能会遇到因软件包依赖问题导致的错误。这通常需要根据错误提示手动安装缺少的...
盘点汇总Docker磁盘环境的清理方法.docx
3. **更新YUM缓存**:运行`yum clean all`来清理YUM的缓存,然后使用`yum makecache`创建新的缓存,这样YUM就可以找到新添加的Docker仓库。 4. **安装Docker**:现在你可以通过YUM安装Docker了。运行`yum install ...
9. **卷插件**:Docker还支持卷插件,允许用户使用第三方存储解决方案(如NFS、Ceph、GlusterFS等)来扩展Docker的存储能力,满足更复杂的企业级存储需求。 10. **最佳实践**:在实际应用中,应尽量避免在容器的 `/...
Crontab是一个在Unix系统中用于定时执行任务的工具,通常被用于运行定期任务如备份、清理日志等。Docker容器化技术允许我们将应用打包并运行在隔离的环境中,这使得它变得非常流行。然而,将Crontab运行在Docker容器...
在Docker环境中,管理和清理日志对于保持系统稳定性和优化磁盘使用至关重要。本文将详细介绍如何查看和清理Docker容器日志,以及如何通过配置来限制日志的大小,从而达到“治本”的目的。 首先,当我们遇到Docker...
如果问题确实是由于缺少docker.socket文件,还有另外两种解决方案: 1. 卸载Docker,然后重新安装。这个操作能够重新创建需要的docker.socket文件。 2. 创建一个新的/usr/lib/systemd/system/docker.socket文件,并...
Docker容器在启动/重启的时候会往 /var/lib/docker 中写东西,如果你在启动docker容器遇到 No space left on device 的问题,可以按照下面的步骤进行清理相关的日志操作。 1、 对 /var/lib/docker/containers 下的...
总之,遇到Docker中Tomcat启动报端口被占用的错误时,首先要检查和清理占用端口的进程,然后通过端口映射或修改配置文件来避免未来的冲突。记住,良好的容器和端口管理是维持Docker环境稳定运行的关键。
【描述】 Docker FPM Wrapper 是一个专为在Docker容器中高效运行PHP-FPM应用设计的解决方案。它着重于日志记录、Prometheus监控以及在Kubernetes(K8s)环境中的优雅关闭功能,以确保服务的稳定性和性能。此项目特别...
Docker 1.12 版本相较于之前的 1.9 版本引入了许多新特性,比如增强的网络功能和 Swarm 集群管理,这些改进使得 Docker 成为了更强大的容器化解决方案。以下是在 CentOS 7 上安装 Docker 1.12 的详细步骤: 首先,...
1. **启动和停止docker-compose服务**:在测试开始前,插件会自动启动docker-compose文件中定义的服务,并在测试结束后清理这些服务,确保测试环境的独立性。 2. **服务绑定到测试函数**:通过pytest标记,我们可以...
这个配置为日志管理和分析提供了灵活且高效的解决方案,尤其适用于分布式系统和云环境。 1. **Elasticsearch**: - **Elasticsearch** 是一个开源的分布式搜索引擎,以其实时性、可扩展性和高性能而闻名。它支持...
用于创建自定义Sitecore图像的示例解决方案,具有用于容器开发的推荐文件夹结构(请参阅custom-images )。 用于基于容器的Sitecore实例准备( init.ps1 )和清理( clean.ps1 )的示例PowerShell脚本。 Docker...
解决方案:可以清理磁盘释放资源,或者通过修改 Kubelet 的配置参数 imagefs.available 来提高阈值,然后重启 Kubelet。 六、kubectl 查看日志时提示: Error from server: Get ...
2. 使用Docker日志API远程重定向:虽然可以避免磁盘占用问题,但仍然需要Agent来清理日志,可能引入运维复杂度,并需要处理重连时的日志回溯。 3. 容器内进程直接管理日志:这会降低系统的透明性和控制性,且可能...