DockerFile:构建docker镜像的指令集合文件;通过该文件可以使dockerImage被自动构建出来。
书写规范
-
格式:
#
: 注释- 指令用大写,内容用小写
- docker 是按顺序执行Dockerfile里的指令集喝的。(上 —> 下)
- 每一个Dockerfile 的第一个非注释行指令,必须为"FROM" 指令,用于为镜像文件构建过程中,指定基准镜像,后续的指令运行于此基准镜像
所提供的有耐性环境中。- 实践中,基准镜像可以是任何可用镜像文件,默认情况下,
docker build
会在docker主机(本地)上查找指定的镜像文件,当其在本地不存
在时,则会从docker registry(远端)上拉取所需的镜像文件。
- 实践中,基准镜像可以是任何可用镜像文件,默认情况下,
-
注意:指令大小写不敏感,但建议上述规则
核心Dockerfile指令
4组核心的Dockerfile指令 (初学docker必会指令,后面在从官网学习其他指令)
USER/WORKDIR 指令
- USER 指令:指定主进程使用什么角色运行。
- WORKDIR: 类似
cd
命令
FROM docker.io/snowlive/nginx-with-curl:v1.19.0
USER nginx
WORKDIR /usr/share/nginx/html
- 例子:
vim Dockerfile
> FROM docker.io/snowlive/nginx-with-curl:v1.19.0
> USER nginx
> WORKDIR /usr/share/nginx/html
docker build . -t snowlive/nginx-with-curl-with-workdir:v0.0.1
ADD/EXPOSE 指令
- ADD: 类似
COPY
指令,往容器放文件的指令 - EXPOSE: 指定容器的哪个端口被暴露出来。 (不能指定外部映射端口,切需要跟
run -P
结合使用,用户映射宿主的随机端口)
FROM snowlive/nginx-with-cur:v1.19.0
ADD index.html /usr/share/nginx/html/index.html
EXPOSE 80
- 例子:
vim Dockerfile
> FROM docker.io/snowlive/nginx-with-curl:v1.19.0
> ADD index.html /usr/share/nginx/html/index.html
> EXPOSE 80
docker build . -t snowlive/nginx-with-curl-with-workdir:v0.0.1
RUN/ENV 指令
- ENV:环境指令
- RUN:构建镜像是,执行的可执行命令
FROM CENTOS
ENV VER 9.9.4-74.el7_6.1
RUN yum install bind-$VER -y
CMD/ENTRYPOINT 指令
CMD 与 ENTRYPOINT 指令作用相同,使用方式略有不同
- CMD:启动容器时,执行的命令。(可能会被启动时的指令替换掉,)
FROM centos
RUN yum install httpd -y
CMD ["httpd","-D","FORGEROUND"]
- ENTRYPOINT: image没有cmd命令,默认走 '/entrypoint.sh’脚本
FROM centos
ADD entrypoint.sh /entrypoint.sh
RUN yum install epel-release -q -y && yum install nginx -y
ENTRYPOINT /entrypoint.sh
综合实验:
FROM snowlive/nginx-with-curl:v1.19.0
USER root
ENV WWW /usr/share/nginx/html
ENV CONF /etc/nginx/conf.d
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' > /etc/timezone
WORKDIR $WWW
ADD index.html $WWW/index.html
ADD demo.od.com.conf $CONF/demo.od.com.conf
EXPOSE 80
CMD ["nginx","-g","daemon off;"]
- demo.od.com.conf
server {
listen 80;
server_name demo.od.com;
root /usr/share/nginx/html;
}