前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >快速学习Docker-Docker-file的指令格式

快速学习Docker-Docker-file的指令格式

作者头像
cwl_java
发布2019-11-04 11:36:59
4310
发布2019-11-04 11:36:59
举报
文章被收录于专栏:cwl_Javacwl_Java

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

本文链接:https://blog.csdn.net/weixin_42528266/article/details/102871377

指令主要分为两种
  • 注释 : # Comment
  • 指令 : INSTRUCTION argument
FROM(包含两种格式)
  • FROM
  • FROM :

image要求是已经存在的镜像,我们也称为基础镜像.必须是第一条非注释指令

MAINTAINER

指定镜像的作者信息,包含镜像的所有者和联系信息.

RUN:
  • 指定当前镜像中运行的命令
代码语言:javascript
复制
RUN  <command> (shell模式)
        /bin/sh -c command
        RUN echo hello
代码语言:javascript
复制
RUN [“executable”,”param1”,”param2”] (exec模式)
RUN [“/bin/bash”,”-c”,”echo hello”]

每个RUN命令都会在当前镜像的上层创建一个新的镜像来运行指令.

EXPOSE
  • 指定运行该镜像的容器使用的端口.
  • 虽然我们在构建镜像的时候暴露了端口号,但是我们在运行容器的时候依然需要指定端口的映射.
  • 我们使用EXPOSE只是告诉Docker运行该镜像的容器会使用80端口,出于安全的考虑,docker并不会打开该端口.
  • 而是需要我们在使用该镜像运行容器的时候指定端口的映射.
CMD
  • CMD指令提供容器默认运行的命令,和之前讲的RUN指令类似.都是执行一个命令,但是RUN命令指定的命令是在镜像构建的过程运行的.
  • CMD的命令是在容器运行的时候运行的.如果我们在docker run命令中指定运行的命令的时候,CMD的指令会被覆盖,默认命令就不会执行.
  • CMD命令是指定容器启动的时候默认命令.
  • 两种模式.
    • CMD [“executable”,”param1”,”param2”] (exec模式)
    • CMD command param1 param2 (shell 模式)
    • CMD [”param1”,”param2”] (作为ENTRYPOINT指令的默认参数.)

示例:

在这里插入图片描述
在这里插入图片描述
  • 通过构建的镜像来创建容器
代码语言:javascript
复制
docker run -p 80 --name cmd_test1 -itd lanxw0720/df_test3
docker top cmd_test1
  • 发现已经启动nginx了.
  • 如果我们在启动的时候指定了参数,默认的CMD命令就会被覆盖了.
ENTRYPOINT
  • 这个和我们刚刚讲的CMD指令非常相似,唯一的区别:不会给docker run的启动命令给覆盖.
  • 如果需要覆盖ENTRYPOINT的指令,需要在docker run使用docker run --entrypoint覆盖.
  • ENTRYPOINT [“executable”,”param1”,”param2”] (exec模式)
  • ENTRYPOINT command param1 param2 (shell 模式)

示例:

在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
	docker build -t="lanxw0720/df_test4" .
	docker run -p 80 --name ep_test1 -d lanxw0720/df_test4 
	docker ps -l
  • 可以发现,启动的容器依然使用的ENTRYPOINT指定的命令执行.
ADD
  • 将文件和目录复制到使用dockerfile构建的镜像中.
  • 目标的来源可以本地的地址也可以是远程地址.
  • 如果是本地地址,本地地址必须是构建目录中的相对地址
  • 对于远程URL,docker并不推荐使用,更建议使用的是curl或者wget的命令来获取
  • 目标路径需要指定镜像中的绝对路径
  • ADD …
  • ADD “”…””
COPY:

示例:

在这里插入图片描述
在这里插入图片描述
  • 在Dockerfile所在目录添加index.html文件
在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
	docker build -t="lanxw0720/df_test6" .
	docker run -p 80 --name add_test1 -d lanxw0720/df_test6
	curl http://127.0.0.1:32775
VOLUME

用于基于镜像创建的容器添加卷,一个卷可以存在一个或者多个容器的特定目录.这个目录可以绕过联合文件系统.提供共享数据和持久化数据的 功能.(后面单独讲)

WORKDIR:
代码语言:javascript
复制
WORKDIR /path/to/workdir
  • 这个指令从指令创建一个容器是,在容器内部设置工作目录.ENTRYPOINT和CMD的命令都会在这个目录下执行.我们也可以使用这个命令给后续的构建中指定工作目录.通常会使用绝对路径,如果使用了相对路径,那这个路径会一致传递下去.如下所示:
代码语言:javascript
复制
WORKDIR /a
WORKDIR b
WORKDIR c
RUN pwd

*结果====>/a/b/c*

ENV
代码语言:javascript
复制
	ENV <key><value>
	ENV <key><value>...
  • 这个指令主要是来设置环境变量,这个环境变量在构建过程中和运行过程中都有效.
USER
代码语言:javascript
复制
	USER daemon
  • 指定镜像会以什么样的用户去运行.
  • 比如:USER nginx
  • 基于该镜像启动的容器就会以nginx的用户来运行.
  • 如果没有指定USER,容器会使用root用户来运行.
ONBUILD
代码语言:javascript
复制
	ONBUILD [INSTRUCTION]
  • 镜像触发器.
  • 当一个镜像被其他镜像作为基础镜像时执行
  • 会在构建过程中插入指令

示例:

在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
docker run -p 80 --name onbuild_test1 -d lanxw0720/df_test7
curl http://127.0.0.1:32776
  • 发现在构建这个镜像的时候并没有执行COPY命令.
  • 接下来我们基于这个镜像来构建新的镜像.
在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
docker build -t="lanxw0720/df_test8" .
docker run -p 80 --name onbuild_test2 -d lanxw0720/df_test8
curl http://127.0.0.1:32777
  • 此时发现已经执行COPY命令了.
DockerFile的构建过程
  • 1.从基础镜像运行一个容器.
  • 2.执行一条指令,对容器做出修改.
  • 3.执行类似docker commit 的操作,提交一个新的镜像层.
  • 4.再基于刚提交的镜像运行一个新容器.
  • 5.执行Dockerfile中的下一条指令,知道所有指令执行完毕.

docker build会删除中间层创建的容器,但是不会删除中间层创建的镜像.我们可以使用docker run 的方式来运行中间层镜像.从而查看每一步创建后的镜像的实际状态,这就给了我们调试镜像的能力. docker会把之前创建过的中间层镜像建立成缓存,第二次构建的时候其实就直接中缓存中拿到中间层的镜像.但是有些时候我们不想使用缓存.

代码语言:javascript
复制
docker build --no-cache
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-11-02 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 指令主要分为两种
  • FROM(包含两种格式)
  • MAINTAINER
  • RUN:
  • EXPOSE
  • CMD
  • ENTRYPOINT
  • ADD
  • COPY:
  • VOLUME
  • WORKDIR:
  • ENV
  • USER
  • ONBUILD
  • DockerFile的构建过程
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档