【Docker】从零开始:17.Dockerfile基本概念

【Docker】从零开始:17.Dockerfile

概述

1.什么是Dockerfile

  • Dockerfile是一个包含用于构建Docker映像的指令的文本文件。这些指令可以包括指定基础映像、添加文件、设置环境变量、执行命令等。Docker通过读取Dockerfile中的指令,自动生成映像。
  • Dockerfile是自定义镜像的一套规则
  • Dockerfile由多条指令构成,Dockerfile中的每一条指令都会对应于Docker镜像中的每一层
  • Dockerfile每条保留字指令都必须为大写字母且后面要跟随至少一个参数
  • Dockerfile每行支持一条指令,每条指令可携带多个参数,一条指令可以用&&方式,去写多条指令。
  • Dockerfile支持以"#"为开头的注释
  • Dockerfile每条指令都会创建一个新的镜像层并对镜像进行提交

2.Dockerfile构建三大步骤

编写Dockerfile文件 docker build命令构建镜像 docker run依镜像运行容器实例

3.Docker执行Dockerfile流程

docker从基础镜像运行一个容器 执行一条指令并对容器作出修改 执行类似docker commit的操作提交一个新的镜像层 docker再基于刚提交的镜像运行一个新容器 执行dockerfile中的下一条指令直到所有指令都执行完成

一张图理解Dockerfile

常用保留指令

~FROM~

基础镜像,当前新镜像是基于哪个镜像的,指定一个已经存在的镜像作为模板,第一条必须是from

~MAINTAINER~

镜像维护者的姓名和邮箱地址

~RUN~

容器构建时需要运行的命令

两种格式

  • shell 格式
bash 复制代码
RUN yum -y install vim
  • exec 格式
bash 复制代码
RUN ["可执行文件","参数1","参数2",....]
RUN ["./test.sh","yes","1"] #等价于 RUN ./test.sh yes 1

~EXPOSE~

当前容器对外暴露出的端口

~WORKDIR~

指定在创建容器后,终端默认登陆的进来工作目录,一个落脚点

~USER~

指定该镜像以什么样的用户去执行,如果都不指定,默认是root

~ENV~

用来在构建镜像过程中设置环境变量

bash 复制代码
ENV MY_PATH /usr/mytest

这个环境变量可以在后续的任何RUN指令中使用,这就如同在命令前面指定了环境变量前缀一样;

也可以在其它指令中直接使用这些环境变量

比如:WORKDIR $MY_PATH

~ADD~

将宿主机目录下的文件拷贝进镜像且会自动处理URL和解压tar压缩包

~COPY~

类似ADD,拷贝文件和目录到镜像中。

将从构建上下文目录中 <源路径> 的文件/目录复制到新的一层的镜像内的 <目标路径> 位置

两种格式

  • shell 格式
bash 复制代码
COPY src dest
  • exec 格式
bash 复制代码
COPY ["src", "dest"]

<src源路径>:源文件或者源目录

<dest目标路径>:容器内的指定路径,该路径不用事先建好,路径不存在的话,会自动创建。

~VOLUME~

容器数据卷,用于数据保存和持久化工作

~CMD~

指定容器启动后的要干的事情

两种格式

  • shell 格式
bash 复制代码
CMD <命令>
CMD cd ~
  • exec 格式
bash 复制代码
CMD  ["可执行文件","参数1","参数2",....]

<src源路径>:源文件或者源目录

<dest目标路径>:容器内的指定路径,该路径不用事先建好,路径不存在的话,会自动创建。

注意

  • Dockerfile 中可以有多个 CMD 指令,但只有最后一个生效,CMD 会被 docker run 之后的参数替换
  • 它和前面RUN命令的区别
    • CMD是在docker run 时运行。
    • RUN是在 docker build时运行。

~ENTRYPOINT~

也是用来指定一个容器启动时要运行的命令

类似于 CMD 指令,但是ENTRYPOINT不会被docker run后面的命令覆盖,

而且这些命令行参数会被当作参数送给 ENTRYPOINT 指令指定的程序

命令格式:

bash 复制代码
ENTRYPOINT  ["可执行文件","参数1","参数2",....]

ENTRYPOINT可以和CMD一起用,一般是变参才会使用 CMD ,这里的 CMD 等于是在给 ENTRYPOINT 传参。

当指定了ENTRYPOINT后,CMD的含义就发生了变化,不再是直接运行其命令而是将CMD的内容作为参数传递给ENTRYPOINT指令,他两个组合会变成ENTRYPOINT "[CMD]"

案例如下:假设已通过 Dockerfile 构建了 nginx:test 镜像:

是否传参 按照dockerfile编写执行 传参运行
Docker命令 docker run nginx:test docker run nginx:test -c /etc/nginx/new.conf
衍生出的实际命令 nginx -c /etc/nginx/nginx.conf nginx -c /etc/nginx/new.conf

如果 docker run 后面指定参数 会覆盖cmd里面的参数

相关推荐
怡雪~6 分钟前
K8s的水平自动扩容和缩容HPA
云原生·容器·kubernetes
史努比.8 分钟前
HPA - k8s自动伸缩机制
云原生·容器·kubernetes
运维&陈同学1 小时前
【kafka01】消息队列与微服务之Kafka详解
运维·分布式·后端·微服务·云原生·容器·架构·kafka
蜗牛丨2 小时前
Go Vue3 CMS管理后台(前后端分离模式)
mysql·docker·go·vue3·axios·gin·jwt·分页·跨域·ant design vue·log·gorm·otp动态码登录·validator·模型绑定·权限判断
菜鸟小灰灰2 小时前
搭建私有docker仓库
运维·docker·容器
一只小菜鸡2 小时前
python+django5.1+docker实现CICD自动化部署springboot 项目前后端分离vue-element
python·docker·自动化
csdn_金手指2 小时前
docker 通过Dockerfile自定义的镜像部署Springboot项目
spring boot·docker·容器
Karoku0663 小时前
【docker集群应用】Docker网络与资源控制
运维·数据库·docker·容器
Jacket Li3 小时前
Kubeadm 安装 Kubernetes 高可用集群 v1.30.0
云原生·容器·kubernetes
泰山小张只吃荷园4 小时前
期末Python复习-输入输出
java·前端·spring boot·python·spring cloud·docker·容器