在Docker
中创建镜像最常用的方式,就是使用Dockerfile
。Dockerfile
是一个Docker
镜像的描述文件,Dockerfile
包含了一条条的指令,每一条指令构建一层,因此每一条指令的内容,就是描述该层应当如何构建。
Dockerfile
思维导图Dockerfile
示例# FROM指定所需依赖的基础镜像 ,格式:FROM <image>:<tag> FROM java:8 # 持久化到指定目录 VOLUME /tmp # ADD复制文件,格式:ADD <src> <dest> ADD eureka-server-1.0-SNAPSHOT.jar app.jar # RUN在容器构建过程中执行的命令,格式:RUN <command> RUN bash -c "touch /app.jar" # EXPOSE声明需要对外暴露的端口 EXPOSE 8761 #ENTRYPOINT 指定docker容器启动时执行的命令 ##"-Djava.security.egd=file:/dev/./urandom" 加快随机数产生过程 ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"] 复制代码
Dockerfile
常用指令指明构建的新镜像是来自于哪个基础镜像,例如:
FROM centos:6 复制代码
指明镜像维护者及其联系方式(一般是邮箱地址),例如:
MAINTAINER DuebassLei <1130122701@qq.com> 复制代码
不过,MAINTAINER
并不推荐使用,更推荐使用LABEL来指定镜像作者,例如:
LABEL maintainer="DuebassLei" 复制代码
构建镜像时运行的Shell
命令,例如:
RUN ["yum", "install", "httpd"] RUN yum install httpd 复制代码
启动容器时执行的Shell
命令,例如:
CMD ["-C", "/start.sh"] CMD ["/usr/sbin/sshd", "-D"] CMD /usr/sbin/sshd -D 复制代码
声明容器运行的服务端口,例如:
EXPOSE 80 443 复制代码
设置环境内环境变量,例如:
ENV MYSQL_ROOT_PASSWORD 123456 ENV JAVA_HOME /usr/local/jdk1.8.0_45 复制代码
拷贝文件或目录到镜像中,例如:
ADD <src>...<dest> ADD html.tar.gz /var/www/html ADD https://xxx.com/html.tar.gz /var/www/html 复制代码
***PS:***如果是URL或压缩包,会自动下载或自动解压。
拷贝文件或目录到镜像中,用法同ADD,只是不支持自动下载和解压,例如:
COPY ./start.sh /start.sh 复制代码
启动容器时执行的Shell
命令,同CMD
类似,只是由ENTRYPOINT
启动的程序不会被docker run命令行指定的参数所覆盖,而且,这些命令行参数会被当作参数传递给ENTRYPOINT指定指定的程序,例如:
ENTRYPOINT ["/bin/bash", "-C", "/start.sh"] ENTRYPOINT /bin/bash -C '/start.sh' 复制代码
***PS:***Dockerfile
文件中也可以存在多个ENTRYPOINT
指令,但仅有最后一个会生效。
指定容器挂载点到宿主机自动生成的目录或其他容器,例如:
VOLUME ["/var/lib/mysql"] 复制代码
***PS:***一般不会在Dockerfile中用到,更常见的还是在docker run的时候指定-v数据卷。
为RUN、CMD和ENTRYPOINT执行Shell命令指定运行用户,例如:
USER <user>[:<usergroup>] USER <UID>[:<UID>] USER edisonzhou 复制代码
为RUN、CMD、ENTRYPOINT以及COPY和AND设置工作目录,例如:
WORKDIR /data 复制代码
告诉Docker如何测试容器以检查它是否仍在工作,即健康检查,例如:
HEALTHCHECK --interval=5m --timeout=3s --retries=3 \ CMD curl -f http:/localhost/ || exit 1 复制代码
一些选项的说明:
--interval=DURATION (default: 30s)
:每隔多长时间探测一次,默认30秒-- timeout= DURATION (default: 30s)
:服务响应超时时长,默认30秒--start-period= DURATION (default: 0s)
:服务启动多久后开始探测,默认0秒--retries=N (default: 3)
:认为检测失败几次为宕机,默认3次一些返回值的说明:
0
:容器成功是健康的,随时可以使用1
:不健康的容器无法正常工作2
:保留不使用此退出代码在构建镜像时,指定一些参数,例如:
FROM centos:6 ARG user # ARG user=root USER $user 复制代码
这时,我们在docker build时可以带上自定义参数user了,如下所示:
docker build --build-arg user=DuebassLei Dockerfile . 复制代码