DockerFile 构建过程解析 | 学习笔记

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
简介: 快速学习 DockerFile 构建过程解析

开发者学堂课程【Docker 快速入门:DockerFile 构建过程解析】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/616/detail/9406


DockerFile 构建过程解析

内容介绍:

一.举例

二.Dockerfile 内容基础知识

三.Docker 执行 Dockerfile 的大致流程

四.小总结

 

一.举例

DockerFile 构建过程解析跟我们学习 Java 时一样,比如在 Java 中定义 class Book,

class Book

{

private int id;

public Book()

{

}

System.out.print();

}

static{

}

}

类的加载机制一样,其中还有类的代码块。Static 静态代码块,各自的加载顺序有一定的语法规则。既然是类的加载顺序有一定的语法规则,那么 dockerfile 也有一定的解析过程。

 

二.Dockerfile 内容基础知识

1. 每条保留字指令都必须为大写字母且后面要跟随至少一个参数

命令后的内容不能为空,否则会因为空指针异常或语法格式问题而报错。保留字指令会在后续章节进行讲述。

2. 指令按照从上到下,顺序执行

3. #表示注释

4.每条指令都会创建一个新的镜像层,并对镜像进行提交

每次构建形成镜像1,再在镜像1的基础上再添加新内容构建镜像2,以此叠加,最终在最外层的镜像就是提交的镜像

 

三.Docker 执行 Dockerfile 的大致流程

1. docker 从基础镜像运行一个容器

一定要有基础镜像 strach

2. 执行一条指令并对容器做出修改

3. 执行类似 docker commit 的操作提交一个新的镜像层

在基础镜像之后又添加 Centos6.8 形成新的镜像,以此类推,层层加码

4. docker 再基于刚提交的镜像运行一个新容器

5. 执行 dockerfile 中的下一条指令直到所有指令执行完成

 

四.小总结

1. 从应用软件的角度来看,Dockerfile、Dockerfile 镜像与 Docker 容器分别代表软件的三个不同阶段。

2. Dockerfile 是软件的原料

3. Dockerfile 镜像是软件的交付品

4. Docker 容器则可以认为是软件的运行态

5. Dockerfile 面向开发,Dockerfile 镜像成交付标准(以前开发人员只需要提交代码war 包,运维工程师负责运行微服务,但当微服务器数量过大时,运维工程师体量也就过大,后期我们会学习高级篇相关的持续支撑与发布,开发人员就需要提交标准或是镜像,运维工程师的工作量也就减少了),Docker 容器则涉及部署与运维,三者缺一不可,合力充当 Docker 体系的基石。

6.Dockerfile 保留关键字,构建后形成 Docker 镜像,按照新的镜像运行后获得 Docker 容器内镜像中的进程,记为具体的容器实例。

image.png

7.Dockerfile,需要定义一个 Dockerfile, Dockerfile 定义了进程需要的一切东西。

Dockerfile 涉及的内容包括执行代码或者是文件、环境、变量、依赖包、运行时环境、动态链接库、操作系统的发行版、服务进程和内核进程(当应用进程需要和系统服务和内核进程打交道,这时需要考虑如何设计 namespace 的权限控制)等等:
8.Docker 镜像,在用 Dockerfile 定义一个文件之后,docker build 时会产生一个 Docker 镜像,当运行 Docker 镜像时,会真正开始提供服务,
9.Docker 容器,容器足直接提供服务的。

相关文章
|
26天前
|
前端开发
深入解析React Hooks:构建高效且可维护的前端应用
本文将带你走进React Hooks的世界,探索这一革新特性如何改变我们构建React组件的方式。通过分析Hooks的核心概念、使用方法和最佳实践,文章旨在帮助你充分利用Hooks来提高开发效率,编写更简洁、更可维护的前端代码。我们将通过实际代码示例,深入了解useState、useEffect等常用Hooks的内部工作原理,并探讨如何自定义Hooks以复用逻辑。
|
16天前
|
监控 安全 Java
构建高效后端服务:微服务架构深度解析与最佳实践###
【10月更文挑战第19天】 在数字化转型加速的今天,企业对后端服务的响应速度、可扩展性和灵活性提出了更高要求。本文探讨了微服务架构作为解决方案,通过分析传统单体架构面临的挑战,深入剖析微服务的核心优势、关键组件及设计原则。我们将从实际案例入手,揭示成功实施微服务的策略与常见陷阱,为开发者和企业提供可操作的指导建议。本文目的是帮助读者理解如何利用微服务架构提升后端服务的整体效能,实现业务快速迭代与创新。 ###
48 2
|
25天前
|
前端开发 开发者 容器
构建响应式Web界面:Flexbox与Grid布局的深度解析
【10月更文挑战第11天】本文深入解析了CSS3中的Flexbox和Grid布局,探讨了它们的特点、应用场景及使用方法。Flexbox适用于一维布局,如导航栏;Grid布局则适用于二维布局,如复杂网格。通过示例代码和核心属性介绍,帮助开发者灵活构建响应式Web界面。
47 5
|
27天前
|
存储 SQL 分布式计算
湖仓一体架构深度解析:构建企业级数据管理与分析的新基石
【10月更文挑战第7天】湖仓一体架构深度解析:构建企业级数据管理与分析的新基石
41 1
|
1月前
|
开发框架 缓存 前端开发
electron-builder 解析:你了解其背后的构建原理吗?
本文首发于微信公众号“前端徐徐”,详细解析了 electron-builder 的工作原理。electron-builder 是一个专为整合前端项目与 Electron 应用的打包工具,负责管理依赖、生成配置文件及多平台构建。文章介绍了前端项目的构建流程、配置信息收集、依赖处理、asar 打包、附加资源准备、Electron 打包、代码签名、资源压缩、卸载程序生成、安装程序生成及最终安装包输出等环节。通过剖析 electron-builder 的原理,帮助开发者更好地理解和掌握跨端桌面应用的构建流程。
63 2
|
14天前
|
存储 运维 监控
运维技术深度解析:构建高效、稳定的运维体系
【10月更文挑战第22天】运维技术深度解析:构建高效、稳定的运维体系
91 0
|
14天前
|
人工智能 运维 监控
运维技术深度解析:构建高效、稳定的IT基础设施
【10月更文挑战第22天】运维技术深度解析:构建高效、稳定的IT基础设施
38 0
|
14天前
|
机器学习/深度学习 边缘计算 运维
运维技术深度解析:构建高效、稳定的IT基础设施
【10月更文挑战第22天】运维技术深度解析:构建高效、稳定的IT基础设施
28 0
|
23天前
|
开发框架 JavaScript 前端开发
Electron技术深度解析:构建跨平台桌面应用的利器
【10月更文挑战第13天】Electron技术深度解析:构建跨平台桌面应用的利器
127 0
|
25天前
|
机器学习/深度学习 存储 自然语言处理
基础与构建:GraphRAG架构解析及其在知识图谱中的应用
【10月更文挑战第11天】随着数据的不断增长和复杂化,传统的信息检索和生成方法面临着越来越多的挑战。特别是在处理结构化和半结构化数据时,如何高效地提取、理解和生成内容变得尤为重要。近年来,一种名为Graph Retrieval-Augmented Generation (GraphRAG) 的新架构被提出,它结合了图神经网络(GNNs)和预训练语言模型,以提高多模态数据的理解和生成能力。本文将深入探讨GraphRAG的基础原理、架构设计,并通过实际代码示例展示其在知识图谱中的应用。
69 0

推荐镜像

更多
下一篇
无影云桌面