11.docker镜像分层&dockerfile优化

docker镜像的分层(kvm 链接克隆,写时复制的特性)

镜像分层的好处:复用,节省磁盘空间,相同的内容只需加载一份到内存。

修改dockerfile之后,再次构建速度快

分层:就是在原有的基础镜像上新增了服务或者软件,也就是文件发生了大小变化。

例如,底层centos6.9,在这上新增nginx,在安装php;

通过镜像查看历史命令就能看出kod:v2镜像的大小变化有10层;注:下图基于基础镜像centos6.9就是一层

因为每一次构建镜像的时候都会起一个临时容器ID,执行下一个容器便会删除上一个容器ID,依次类推。

镜像历史命令能看构建10层,也就是对应dockerfile脚本里面的发生文件大小变化的10条命令;

我将kod:v2镜像导出,然后删除kod:v2镜像,然后在导入,就可以清晰可见的层数
注释:由于centos6.9镜像已经存在,所以就直接复用了,就不会显示层数。

导入镜像,这里显示7层,正常来说应该是10层,因为这里有3层是在镜像中已经存在的,所以被直接复用。
注释:layer意思为:层

从上面的结论可以得出,也就是构建脚本中的指令RUN越多层数就很多。下图所示
注释:docker镜像中分层限制最大128层。层数越多加载就越慢,所以越少越好

dockerfile自动构建优化

dockerfile脚本优化:

1:尽可能选择体积小linux,如alpine(5M左右)

2:尽可能合并RUN指令,清理无用的文件(yum缓存,源码包)

3:修改dockerfile,把变化的内容尽可能放在dockerfile结尾

4: 使用.dockerignore,减少不必要的文件ADD . /html

根据上面几条优化规则,将kod服务构建的dockerfile脚本进行优化操作

powershell 复制代码
[root@yunlong /data/dockerfile/kod]# cat dockerfile  
#!/bin/bash
FROM centos:6.9
RUN curl -o /etc/yum.repos.d/CentOS-Base.repo https://www.xmpan.com/Centos-6-Vault-Aliyun.repo && \
curl -o /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-archive-6.repo && \
yum install  nginx php-fpm php-gd php-mbstring unzip -y && \
yum clean all 
ADD kodexplorer4.40.zip /opt/
RUN cd /opt/ && \
unzip kodexplorer4.40.zip && \
rm -rf kodexplorer4.40.zip && \ 
chown -R nginx:nginx .
ADD nginx.conf /etc/nginx/nginx.conf
ADD www.conf /etc/php-fpm.d/www.conf
ADD init.sh /init.sh
CMD ["/bin/bash","/init.sh"]

重新构建镜像

powershell 复制代码
docker build --network=host -t kod:v3 .

查看镜像比之前kodv2小了162M

导出镜像查看,kod:v3小了156M

在查看镜像历史命令显示kod:v2是10层,kod:v3则为7层。

相关推荐
会Tk矩阵群控的小木7 小时前
小红书矩阵软件:基于Python+ADB的多设备批量管理自动化脚本实战
运维·python·adb·矩阵·自动化·新媒体运营·个人开发
NetInside_7 小时前
某市级水利单位全流量监测与可视化交付实践
运维·网络
ai_coder_ai7 小时前
使用ocr实现自动化脚本
运维·自动化·ocr
帅大大的架构之路7 小时前
linux上面的一些小知识点
linux·运维·服务器
光电笑映7 小时前
进程间通信:深入 System V IPC:共享内存、消息队列与信号量
linux·运维·服务器·c++
向日葵.7 小时前
linux & qnx & git 命令 2
linux·运维·git
IT界的老黄牛7 小时前
MongoDB 主从切换排查实战:从 docker ps 到 jq,一套 SOP 定位死因
数据库·mongodb·docker
丑过三八线7 小时前
Systemd Cgroup 驱动详解
linux·ubuntu·容器
睡不醒男孩0308237 小时前
第四篇:数据库国产化与信创替代的守护者:基于CLup的异构数据库一站式运维平台构建
运维·数据库·金融·clup·中启乘数
Jonm7 小时前
exsi系统使用storcli重组raid阵列(不停机)
运维·esxi·raid