docker commit之后镜像越来越大解决办法

每次对docker的镜像进行增删改之后,它的体积都会扩充,甚至大到5G左右,在项目中是不可以接受的。

查找变大的原因为:

docker容器就是以便于移植和部署著称。那么在docker使用过程中,少不了对容器进行反复的的打包和部署。为了追求容器完整性,往往使用docker commit 容器ID 新镜像名:tag 来操作,再使用save/load对其进行打包/部署镜像。但是根据上面的命令操作往往发现,即使很小的容器经过上述步骤操作几次后得到的镜像仍旧会变得很大很大(即使容器内的文件都被删掉了)。

这主要是由于docker镜像的构建方式是以层的概念来实现的,在容器内所做的所有操作都会在构建镜像时运行一遍,每一个操作所涉及到的内存空间, 都会成为镜像文件的一部分。

看到的大都是压缩容器根目录制作基础镜像或者操作Dockerfile之类的,相对就比较复杂,或者不是我们想要的答案。以下参考文章中的方法1给出比较详细好用的解决方法步骤。

解决方案一

因此查阅文档之后记录一下解决方案,在处理晚之后要打包时,执行以下操作。

进入镜像容器里后,执行命令

复制代码
# 在根目录下将所有的文件打包到根目录下,命名为base_img.tar
tar --exclude=/proc --exclude=/sys --exclude=base_img.tar -cvf base_img.tar  .

# 退出docker环境
exit

# 使用命令进行查看刚才操作的那一个CONTAINER ID
docker ps -a

# 拷贝压缩包到当前目录下,可以改路径
docker cp 容器id:/base_img.tar .

# 导入容器,命名为base_img
cat base_img.tar | docker import - 镜像名:镜像版本

# 最终镜像少了许多的空间
相关推荐
晨晖217 小时前
Linux命令10
linux·运维·服务器
光电笑映17 小时前
深入理解 ELF:从目标文件到程序加载的全过程
linux·运维·服务器·c++
李南想做条咸鱼17 小时前
k8s集群容器访问域名第一次不通,第二次必通如何解决
云原生·容器·kubernetes
WXDcsdn17 小时前
新安装的Debian 12系统开启root用户和ssh登录权限
运维·debian·ssh
FelixBitSoul18 小时前
K8s 调度器黑盒全拆解:拓扑约束数学陷阱 + Go 插件二开实战(避坑全记录)
容器·kubernetes
Agent手记18 小时前
传统工厂的工单自动排程如何用AI解决?从大模型推理到端到端自动化的闭环实战
运维·人工智能·ai·自动化
IT策士18 小时前
Docker 网络进阶:容器间通信与 DNS 解析
网络·docker·容器
code_li18 小时前
Netlify全栈开发:零运维部署实战
运维·服务器·部署
艾莉丝努力练剑19 小时前
【Linux:文件】库的制作与原理进阶
linux·运维·服务器·网络·数据库·c++·人工智能
GZ_TOGOGO19 小时前
sudo 命令详解与安全使用指南
linux·运维·安全