Docker之dockerfile
一、什么是dockerfile
Docker通过对于在dockerfile中的一系列指令的顺序解析实现自动的Image的构建;
通过使用build命令,根据dockerfile的描述来构建镜像;
build的两种方法:
-
- 通过源代码路径的方式;
-
- 通过标准输入流的方式;
通过源代码路径:
-
- Dockerfile需要放置在项目的根目录位置;
- 在构建的时候,Docker client会把整个Context打包发送到docker Server端,然后由Server端负责build镜像,在构建成功后,会删除Context目录;
- docker build -t {镜像名字}{项目的路径,可以是相对路径}
通过标准输入流:
-
- 通过标准输入流的方式获取dockerfile的内容;
- client不会打包上传context目录,因此对于一些ADD、COPY等涉及HOST本地文件复制的操作不能够支持;
- docker build -t {镜像名字} -< Dockerfile路径
build cache:
-
- Dockerfile中的每一个指令执行完毕后,都会提交为一个Image,这样保证了指令间不会有影响;
- docker会尽可能尝试重用之前已经重用之前已经构建的镜像;
- 可以通过在build命令中增加-no-cache的方式来禁用cache
dockerignore:
当选择用源代码路径的方式构建image的时候,通过在根目录下放置.dockerignore文件,来过滤不需要发送到server端的文件
类似于.gitinore的概念
二、Dockerfile指令:
- 只支持docker自己定义的一套指令,不支持自定义
- 大小写不敏感,但是建议全部使用大写
- 根据dockerfile的内容顺序执行
FROM
FROM {base镜像}
必须放在dockerfile的第一行,表示从哪个BaseImage开始构建
MAINTAINER
可选的,用来标示Image作者的地方
RUN
每一个RUN指令都会是在一个新的container里面运行,并提交为一个Image作为下一个RUN的base
一个dockerfile中可以包含多个RUN,按定义顺序执行
RUN支持两种运行方式:
RUN <cmd> 这个会当作/bin/sh -c "cmd"运行
RUN ["executable", "arg1", ....], docker把它当Json的序列来解析,因此必须用双引号,而且executable需要是完整路径;
CMD
CMD的作用是作为执行Container时候的默认行为
当运行Container的时候声明了Command,则不再使用Image中的CMD所定义的命令;
一个dockerfile中只能有一个有效的CMD,当定义多个CMD的时候,只有最后一个才会起作用;
CMD定义三种方式:
-
- CMD <cmd> 这个会当作/bin/sh -c "cmd"来执行
- CMD ["executable", "arg1", "arg2"]
- CMD ["arg1", "arg2"], 这个时候CMD作为ENTRYPOINT的参数;
ENTRYPOINT:
ENTPYPOINT的作用是,把整个Container变成了一个可执行文件,这样不能够通过替换CMD的方法来改变创建Container的方式。但是可以通过参数传递的方式影响到Container内部。
每个Dockerfile只能包含一个ENTRYPOINT,多个ENTRYPOINT只有最后一个能有效;
当定义了ENTRYPOINT以后,CMD只能作为参数进行传递;
ENTRYPOINT定义方式:
ENTPYPOINT ["executable", "arg1", "arg2"], 这种定义方式下,CMD可以通过Json序列的方式来定义ENTRYPOINT的参数,可以通过在运行Container的时候通过指定Command的方式传递参数
ENTRYPOINT <cmd>, 当做/bin/sh -c "cmd"运行;
ADD©:
当在源代码构建的方式下,可以通过ADD和COPY的方式,把Host上的文件或者目录复制到Image
ADD©的源必须在context路径下;
当src为网络URL的情况下,ADD指令可以把它下载到Dest的指定位置,这个在任何build的方式下都可以工作;
ENV:
用来设置环境变量,后续的RUN可以使用它所创建的环境变量;
当创建基于该镜像的Container的时候,会自动拥有设置的环境变量;
WORKDIR:
用来指定当前工作目录
当使用相对目录的情况下,采用上一个WORKDIR指定的目录作为基准;
USER:
指定UID或者username,来决定运行RUN指令的用户
ONBUILD:
ONBUILD作为一个trigger的标记,可以用来trigger任何Dockerfile中的指令;
可以定义多个ONBUILD指令
当下一个镜像B使用镜像A作为Base的时候,在FROM A指令前,会按照顺序执行在构建A时候定义的ONBUILD指令
ONBUILD <DOCKERFILE指令> <Content>
VOLUME:
用来创建一个在Image之外的mount point,用来在多个container之间实现数据共享
运行使用json array的方式定义多个volume
VOLUME ["/var/data1", "/var/data2/"]
或则plain text的情况下定义多个VOLUME指令

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Kubernetes概念介绍和v1版本部署过程
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq1010885678/article/details/48719923 简介: k8s一个开源的,跨主机管理容器应用集群的编排系统,为应用提供了基础的部署、维护和扩缩容机制。 编排:跨Docker主机同一管理容器集群。 目的 简化开发和运维容器集群的工作。 让开发和运维能把这个系统当一台电脑看待。 特点:没有资源调度算法,只关注容器的管理。 核心概念: Cluster,即集群:虚拟机或者物理机的一组集合,运行着Kubernetes ETCD 一个分布式强一致性的key/value存储 可理解为一个存储k8s信息的数据库 Node 工作节点,运行Master节点交付的任务 能运行一个或多个Pods 运行的组件 Kubelet 管理容器的守护进程 管理Docker主机来启动容器的管理程序 定期从etcd获取分配到本机的pod信息,启动或停止容器 接收apiserver的HTTP请求,汇报pod的运行状态 Proxy 服务发现(IP寻址) 定期从etcd获取所有的service根据servi...
- 下一篇
Bossies 2015: The Best of Open Source Software Awards
InfoWorld editors and contributors pick the top open source software for data centers, clouds, developers, data crunchers, and IT pros Whenever you hear someone complain about developer productivity, just slap them. Having slogged through hundreds of open source projects each year for the past several years, I can assure you that developers areextremely productive. Every time we put together this package -- InfoWorld’s annual Best of Open Source Awards, aka the Bossies -- I end up wishing devel...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS8编译安装MySQL8.0.19
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS7设置SWAP分区,小内存服务器的救世主
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- SpringBoot2整合Redis,开启缓存,提高访问速度