Docker 多阶段构建的原理及构建过程展示
Docker多阶段构建是一个优秀的技术,可以显著减少 Docker 镜像的大小,从而加快镜像的构建速度,并减少镜像的传输时间和存储空间。本文将详细介绍 Docker 多阶段构建的原理、用途以及示例。
Docker 多阶段构建的原理
在传统的 Docker 镜像构建中,我们通常需要在 Dockerfile 中指定多个步骤,每个步骤都需要添加一些新的层到镜像中。这样做的问题是,每个层都会添加额外的文件和元数据到镜像中,因此镜像的大小会变得非常大。当需要传输这些镜像到其他地方时,这会消耗大量的时间和网络带宽。
为了解决这个问题,Docker 多阶段构建提供了一种方法来构建一个 Docker 镜像,该镜像只包含必要的文件和元数据,而不包含多余的信息。具体来说,Docker 多阶段构建允许您在同一个 Dockerfile 中定义多个阶段,每个阶段可以独立地构建、测试和优化。在每个阶段结束时,只需将必要的文件和元数据复制到下一个阶段,并舍弃上一个阶段中的多余信息。这样,您就可以在不增加镜像大小的情况下构建出一个可靠的 Docker 镜像。
Docker 多阶段构建的用途
Docker 多阶段构建的主要用途是减少 Docker 镜像的大小。由于每个阶段只包含必要的文件和元数据,所以您可以显著减少 Docker 镜像的大小,并加快构建速度。此外,Docker 多阶段构建还提供了一种简单的方法来构建、测试和优化多个应用程序,因为每个阶段都可以使用不同的环境和工具。
Docker 多阶段构建的示例
下面是一个使用 Docker 多阶段构建构建 Nginx应用程序的示例。该示例分为两个阶段:第一个阶段使用 Alpine 官方镜像来构建应用程序,第二个阶段使用 Alpine镜像 +Nginx运行时文件来运行应用程序。
首先拉取一个alpline镜像,并查看镜像的大小,可以看到只有7M
[root@server159 ~]# docker pull alpine
[root@server159 ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
centos7-python v1 e6a497c56c1c 16 hours ago 526MB
php-fpm v1 0474bd7488fa 39 hours ago 698MB
debian latest 676aedd4776f 3 weeks ago 117MB
alpine latest 8ca4688f4f35 4 weeks ago 7.34MB
centos 7 eeb6ee3f44bd 2 years ago 204MB
nginx 1.18.0 c2c45d506085 2 years ago 133MB
随便创建一个空目录,最好是空的不要有其它文件
然后编写一个Dockerfile文件
[root@server159 alpine]# ls
Dockerfile
[root@server159 alpine]# cat Dockerfile
FROM alpine:latest as relay_nginx
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories && \apk add --no-cache gcc libgcc libc-dev zlib-dev pcre-dev wget make openssl-dev && \wget -c http://nginx.org/download/nginx-1.22.0.tar.gz && \tar xf nginx-1.22.0.tar.gz && \cd nginx-1.22.0 && \./configure --prefix=/usr/local/nginx --with-http_ssl_module --with-http_auth_request_module --with-http_random_index_module && \make && make install && \rm -rf /usr/local/nginx/conf/*.default && \cd ../ && \rm -rf nginx-1.22.0* /var/cache/apk/*ADD ./index.html /usr/share/nginx/html/index.html
EXPOSE 80
EXPOSE 443ENTRYPOINT ["/usr/local/nginx/sbin/nginx","-g","daemon off;"]
然后构建镜像
[root@server159 alpine]# docker build --no-cache -t nginx:alpine-1.0 .
构建完以后查看我们的镜像,可以看到大小为172M
[root@server159 alpine]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx alpine-1.0 e096be22d040 34 seconds ago 172MB
centos7-python v1 e6a497c56c1c 16 hours ago 526MB
php-fpm v1 0474bd7488fa 39 hours ago 698MB
debian latest 676aedd4776f 3 weeks ago 117MB
alpine latest 8ca4688f4f35 4 weeks ago 7.34MB
centos 7 eeb6ee3f44bd 2 years ago 204MB
nginx 1.18.0 c2c45d506085 2 years ago 133MB
构建一个容器查看效果
[root@server159 alpine]# docker run --name nginx-alpine-1.0 -d -p8080:80 nginx:alpine-1.0
21fa466986ab11cfac2c8c23b4772e8c2213d83e2ffc414c289420756106d1ed
去浏览器访问

可以看到容器是正常运行的
然后我们再编写Dockerfile文件,多加一层镜像的构建
[root@server159 alpine]# cat Dockerfile
FROM alpine:latest as relay_nginx
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories && \apk add --no-cache gcc libgcc libc-dev zlib-dev pcre-dev wget make openssl-dev && \wget -c http://nginx.org/download/nginx-1.22.0.tar.gz && \tar xf nginx-1.22.0.tar.gz && \cd nginx-1.22.0 && \./configure --prefix=/usr/local/nginx --with-http_ssl_module --with-http_auth_request_module --with-http_random_index_module && \make && make install && \rm -rf /usr/local/nginx/conf/*.default && \cd ../ && \rm -rf nginx-1.22.0* /var/cache/apk/*FROM alpine:latest as alpine_nginx
RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories && \apk add --no-cache zlib-dev pcre-dev openssl-dev && \rm -rf /var/cache/apk/*COPY --from=relay_nginx /usr/local/nginx /usr/local/nginx
EXPOSE 80
EXPOSE 443ENTRYPOINT ["/usr/local/nginx/sbin/nginx","-g","daemon off;"]
编写完毕以后我们构建一个2.0版本的镜像
[root@server159 alpine]# docker build --no-cache -t nginx:alpine-2.0 .
产看镜像
[root@server159 alpine]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx alpine-2.0 11c2c53e9585 10 seconds ago 24.1MB
nginx alpine-1.0 603a2f2545fe 6 minutes ago 172MB
centos7-python v1 e6a497c56c1c 16 hours ago 526MB
php-fpm v1 0474bd7488fa 39 hours ago 698MB
debian latest 676aedd4776f 3 weeks ago 117MB
alpine latest 8ca4688f4f35 4 weeks ago 7.34MB
centos 7 eeb6ee3f44bd 2 years ago 204MB
nginx 1.18.0 c2c45d506085 2 years ago 133MB
可以惊奇的发现我们2.0的镜像仅仅只有24M,小了好几倍
然后也用2.0的镜像生成一个容器测试一下可用性
[root@server159 alpine]# docker run --name nginx-alpine-2.0 -d -p8081:80 nginx:alpine-2.0
73e2a462573e3c5298ad6e255a95d214aad58ce498becfcac2fde8799c796d1e
然后去网页访问


说明我们的2.0版本镜像也是可以正常运行的
但是却小了好多,那是因为我们构建了两层的镜像,而底层的镜像会被压缩
所以这就是多层镜像构建的好处,在发布的时候可以大大缩减镜像的大小
在这个基础上再定制我们自己想要的镜像,就是一项很好的优化
相关文章:
Docker 多阶段构建的原理及构建过程展示
Docker多阶段构建是一个优秀的技术,可以显著减少 Docker 镜像的大小,从而加快镜像的构建速度,并减少镜像的传输时间和存储空间。本文将详细介绍 Docker 多阶段构建的原理、用途以及示例。 Docker 多阶段构建的原理 在传统的 Docker 镜像构建…...
【开题报告】基于Spring Boot的家装产品展示交易平台的设计与实现
1.研究背景和目的 随着人们对居住环境舒适度和个性化需求的不断提升,家装市场正逐渐发展成为一个重要的消费领域。为了满足消费者对家装产品的需求,建立一个高效、可靠的家装产品展示交易平台变得尤为重要。本项目旨在通过使用Spring Boot框架ÿ…...
MacOS安装git
文章目录 通过Xcode Command Lines Tool安装(推荐)终端直接运行git命令根据流程安装先安装Command Lines Tool后再安装git 官网下载二进制文件进行安装官方国外源下载二进制文件(不推荐)国内镜像下载二进制文件(推荐)安装git 通过Xcode Command Lines Tool安装(推荐) 简单来讲C…...
京东协议算法最新版
环境准备 1 com.jingdong.app.mall11.6.4 入口定位 逆向分析,发现 params 里面有一个 sign 以及请求头里面有一个 jdgs 首先我们发现京东的 sign 是 32 位的,猜测其可能是 md5 之类的 hash 算法,既然是 hash 算法,那么就大概率…...
软考系统架构设计师案例分析知识汇总
软件架构风格 △△△ 软件架构风格是描述某一类特定应用领域中软件系统组织方式和惯用方式。组织方式描述了系统的组成构件和这些构件的组织方式,惯用模式则反映众多系统共有的结构和语义。 面向对象架构风格的特征是将数据表示和基本操作封装在对象中。这种模式的构件是对象…...
MyBatis-plus 代码生成器
具体代码 application.yaml server:port: 8081 #自定义端口号spring:datasource:url: jdbc:mysql://localhost:3306/itcast?useUnicodetrue&characterEncodingutf-8&serverTimezoneGMT%2B8username: rootpassword: 123456driver-class-name: com.mysql.cj.jdbc.Driver…...
运维常识——网络
内网,公网IP 内网IP为专网IP 因为网络资源(IP地址不够,所以引出来了内网IP和IPv6) 内网IP和公网IP之分是为了减缓IP地址不够使用的情况 一般设置代理服务器 设置两张网卡 一张对外一张对内 内部主机将数据转发到内网卡&#…...
《研发效能(DevOps)工程师》课程简介(一)丨IDCF
为贯彻落实《关于深化人才发展体制机制改革的意见》,推动实施人才强国战略,促进专业技术人员提升职业素养、补充新知识新技能,实现人力资源深度开发,推动经济社会全面发展,根据《中华人民共和国劳动法》有关规定&#…...
OMV 介绍及安装
# Time: 2023/11/02 #Author: Xiaohong # 运行电脑: Lenovo X201I (Intel(R) Core(TM) i3 CPU M 370 2.40GHz) # 功能: OMV 介绍及安装 导图 若OMV6 安装Extras 插件失败,可以参考 OMV6 安装Extras 插件失败的解决方法...
JAVA 实现PDF转图片(spire.pdf.free版)
1.引入jar包 导入方法1: 手动引入。将Free Spire.PDF for Java下载到本地,解压,找到lib文件夹下的Spire.PDF.jar文件。在IDEA中打开如下界面,将本地路径中的jar文件引入Java程序: 导入方法2:如果您想通过…...
高效学习工具之AnkiMobile新手入门指南(ios端,包括ipad、ihpone设备)————创建、使用、备份、设置参数、相关资料
文章目录 0 背景0.1 闭环学习0.2 什么是anki0.3 anki践行者经验分享 1 开始使用1.1 导入1.2 创建空白组1.3 创建卡片1.3.1 利用anki创建卡片的两种方法1.3.2 复习材料分类 1.4 筛选(做减法,拆分学习(做子卡牌集合))&am…...
LiveMeida视频接入网关
一、产品简介 视频接入网关主要部署在视频存储节点或视频汇聚节点,面向不同用户,主要用于对接不同厂家、不同型号的摄像机设备,获取摄像机视频后,以统一标准的视频格式和传输协议,将视频推送至上层联网/应用平台。可广…...
我和云栖有个约会
文章目录 云栖大会体验与感受大模型的体验感受 对大会的期待 云栖大会 云栖大会是是阿里巴巴集团主办的年度技术盛会,是云计算、大数据、人工智能等前沿技术产业发展的见证者、参与者和推动者。2023年的云栖大会于10月31日在杭州开幕,吸引了全球的技术专…...
模拟官网编写自定义Grafana Dashboard
前言 我们想编写自定义的Dashboard,类似于官网那样下载的Dashboard,并且能移值到机器主机,如何实现了? ## 官网dashboard https://grafana.com/grafana/dashboards/ 编写 先在虚拟机写好Dashboard 然后下载。json文件如下: {…...
组件局部注册和全局注册
普通组件的注册使用-局部注册 1.特点: 只能在注册的组件内使用 2.实现效果 3.步骤: 创建.vue文件(三个组成部分)在使用的组件内先导入再注册,最后使用 4.使用方式: 当成html标签使用即可 <组件名&…...
【数据结构】模拟实现stack
namespace my_stack {//适配器模式/配接器template <class T,class Containervector<T>>class stack {public:void push(const T& val){_con.push_back(val);}void pop(){_con.pop_back();}const T& top(){return _con.back();}size_t size(){return _con.…...
Hive创建分区表并插入数据
业务中经常会遇到这种需求:数据每天全量更新,但是要求月底将数据单独保存一份以供后期查询某月节点的信息。这时就要考虑用到Hive的分区表实现,即按照月份创建分区表,相当于新的月份数据保存在新表,进而实现保存了历史…...
虚拟机防火墙关闭教程
虚拟机防火墙关闭教程 连接数据库请求超时 教程...
《研发效能(DevOps)工程师》课程简介(二)丨IDCF
为贯彻落实《关于深化人才发展体制机制改革的意见》,推动实施人才强国战略,促进专业技术人员提升职业素养、补充新知识新技能,实现人力资源深度开发,推动经济社会全面发展,根据《中华人民共和国劳动法》有关规定&#…...
EViews| 基础操作 备战下周机考
目录 一、创建工作文件 1、非时间序列数据 2、时间序列数据 二、导入数据 1、导入数据 2、保存数据组合或方程结果 三、估计回归模型 1、估计回归模型 2、回归结果名词解读 四、检验模型设定错误 1、检验是否遗漏变量 2-1、检验是否加入了不相干变量 2-2、惩罚新增…...
反向工程与模型迁移:打造未来商品详情API的可持续创新体系
在电商行业蓬勃发展的当下,商品详情API作为连接电商平台与开发者、商家及用户的关键纽带,其重要性日益凸显。传统商品详情API主要聚焦于商品基本信息(如名称、价格、库存等)的获取与展示,已难以满足市场对个性化、智能…...
R语言AI模型部署方案:精准离线运行详解
R语言AI模型部署方案:精准离线运行详解 一、项目概述 本文将构建一个完整的R语言AI部署解决方案,实现鸢尾花分类模型的训练、保存、离线部署和预测功能。核心特点: 100%离线运行能力自包含环境依赖生产级错误处理跨平台兼容性模型版本管理# 文件结构说明 Iris_AI_Deployme…...
(二)原型模式
原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…...
如何为服务器生成TLS证书
TLS(Transport Layer Security)证书是确保网络通信安全的重要手段,它通过加密技术保护传输的数据不被窃听和篡改。在服务器上配置TLS证书,可以使用户通过HTTPS协议安全地访问您的网站。本文将详细介绍如何在服务器上生成一个TLS证…...
【C++从零实现Json-Rpc框架】第六弹 —— 服务端模块划分
一、项目背景回顾 前五弹完成了Json-Rpc协议解析、请求处理、客户端调用等基础模块搭建。 本弹重点聚焦于服务端的模块划分与架构设计,提升代码结构的可维护性与扩展性。 二、服务端模块设计目标 高内聚低耦合:各模块职责清晰,便于独立开发…...
分布式增量爬虫实现方案
之前我们在讨论的是分布式爬虫如何实现增量爬取。增量爬虫的目标是只爬取新产生或发生变化的页面,避免重复抓取,以节省资源和时间。 在分布式环境下,增量爬虫的实现需要考虑多个爬虫节点之间的协调和去重。 另一种思路:将增量判…...
群晖NAS如何在虚拟机创建飞牛NAS
套件中心下载安装Virtual Machine Manager 创建虚拟机 配置虚拟机 飞牛官网下载 https://iso.liveupdate.fnnas.com/x86_64/trim/fnos-0.9.2-863.iso 群晖NAS如何在虚拟机创建飞牛NAS - 个人信息分享...
LangFlow技术架构分析
🔧 LangFlow 的可视化技术栈 前端节点编辑器 底层框架:基于 (一个现代化的 React 节点绘图库) 功能: 拖拽式构建 LangGraph 状态机 实时连线定义节点依赖关系 可视化调试循环和分支逻辑 与 LangGraph 的深…...
0x-3-Oracle 23 ai-sqlcl 25.1 集成安装-配置和优化
是不是受够了安装了oracle database之后sqlplus的简陋,无法删除无法上下翻页的苦恼。 可以安装readline和rlwrap插件的话,配置.bahs_profile后也能解决上下翻页这些,但是很多生产环境无法安装rpm包。 oracle提供了sqlcl免费许可,…...
xmind转换为markdown
文章目录 解锁思维导图新姿势:将XMind转为结构化Markdown 一、认识Xmind结构二、核心转换流程详解1.解压XMind文件(ZIP处理)2.解析JSON数据结构3:递归转换树形结构4:Markdown层级生成逻辑 三、完整代码 解锁思维导图新…...
