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 - 镜像名:镜像版本

# 最终镜像少了许多的空间
相关推荐
金刚猿6 分钟前
01_虚拟机中间件部署_root 用户安装 docker 容器,配置非root用户权限
docker·中间件·容器
JH_Kong33 分钟前
解决 WSL 中 Docker 权限问题:从踩坑到完整修复
docker·容器
忆~遂愿1 小时前
GE 引擎与算子版本控制:确保前向兼容性与图重写策略的稳定性
大数据·开发语言·docker
Fcy6481 小时前
Linux下 进程(一)(冯诺依曼体系、操作系统、进程基本概念与基本操作)
linux·运维·服务器·进程
袁袁袁袁满1 小时前
Linux怎么查看最新下载的文件
linux·运维·服务器
代码游侠2 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法
Harvey9032 小时前
通过 Helm 部署 Nginx 应用的完整标准化步骤
linux·运维·nginx·k8s
陈桴浮海2 小时前
Kustomize实战:从0到1实现K8s多环境配置管理与资源部署
云原生·容器·kubernetes
珠海西格电力科技3 小时前
微电网能量平衡理论的实现条件在不同场景下有哪些差异?
运维·服务器·网络·人工智能·云计算·智慧城市
释怀不想释怀3 小时前
Linux环境变量
linux·运维·服务器