Dockerfile是一堆指令,每一条指令构建一层,因此每一条指令的内容就是描述该层应当如何构建,在docker build的时候,按照该指令进行操作,最终生成我们期望的镜像文件

Dockerfile常用指令

先上一张通俗易懂的全景图

1.FROM 指令

FROM指令是指定基础镜像,必须为第一个命令

格式:
FROM <image>
FROM <image>:<tag> 示例:
FROM:nginx:latest 温馨提示:tag是可选的,如果不使用tag时,默认会使用latest版本的基础镜像

2.MAINTAINER指令

MAINTAINER指令:镜像维护者的信息

格式:
MAINTAINER <name> 示例:
MAINTAINER Maple <XXXXX@qq.com>

3.COPY/ADD指令

ADD指令:将本地文件添加到容器中,tar类型文件会自动解压(网络压缩资源不会被解压),可以访问网络资源,类似wget

格式:
ADD <src>... <dest>
示例:
#添加所有以"map"开头的文件
ADD map* /mydir/ #添加test目录到`WORKDIR`/relativeDIR/
ADD test relativeDir/

COPY指令:类似于ADD指令,但是不会自动解压文件,也不能访问网络资源

4.WORKDIR指令

WORKDIR指令:工作目录

格式:
WORKDIR /path/to/workdir 示例:
WORKDIR /a #工作目录为/a
WORKDIR b #这时工作目录为/a/b 温馨提示:通过WORKDIR设置工作目录后,Dockerfile中基后的命令RUN、CMD、ENTRYPOINT、ADD、COPY等命令都会在该目录下执行。在使用docker run运行容器时,可以通过-w参数覆盖构建时所设置的工作目录

5.RUN指令

RUN指令:构建镜像过程中运行的Shell命令

格式:
RUN <COMMAND> 示例:
RUN yum install nginx #构建镜像时,运行RUN命令先安装nginx 温馨提示:RUN指令创建的中间镜像会被缓存,并会在下次构建中使用。如果不想使用这些缓存镜像,可以在构建时指定--no-cache参数,如:docker build --no-cache

6.CMD指令

CMD指令:构建容器后调用,也就是在容器启动时才进行调用

格式:
CMD ["executable","param1","param2"] #执行可执行文件,优先
CMD ["param1","param2"] #设置了ENTRYPOINT,则直接调用ENTERPOINT添加参数
CMD command param1 param2 #执行shell内部命令 示例:
CMD ["/usr/bin/wc","--help"]
CMD ping www.qq.com 温馨提示:CMD不同于RUN,CMD用于指定在容器启动后所要执行的命令,而RUN用于指定镜像构建时所要执行的命令

7.ENTRYPOINT指令

ENTRYPOINT指令:设置容器初始化命令,使其可执行化

格式:
ENTRYPOINT ["executable","param1","param2"] #可执行文件优先
ENTRYPOINT command param1 param2 #shell内部命令 示例:
ENTRYPOINT ["/usr/bin/wc","--help"] 温馨提示:ENTRYPOINT与CMD非常类似,不同的是通过docker run执行命令不会覆盖ENTRYPOINT,而docker run命令中指定的任何参数,都会被当做参数再次传递给ENTRYPOINT。Dockerfile中只允许有一个ENTRYPOINT命令,多指定时会覆盖前面的设置,而只执行最后的ENTRYPOINT指令

8.ENV指令

ENV指令:设置环境变量

格式:
ENV <key> <value> #<key>之后的所有内容均会被视为其<value>的组成部分,因此,一次只能设置一个变量
ENV <key>=<value> ... #可以设置多个变量,每个变量为一个"<key>=<value>"的键值对,如果<key>中包含空格,可以使用\来进行转义,也可以通过""来进行标示,另外,反斜线也可以用于续行 示例:
ENV myName Heroge
ENV myCat=fluffy

9.EXPOSE指令

EXPOSE指令:指定与外界交互的端口

格式:
EXPOSE <port> [<port>...] 示例:
EXPOSE 80 443
EXPOSE 8080
EXPOSE 11222/tcp 11211/udp 温馨提示:EXPOSE并不会让容器的端口访问到主机,要使其可访问,需要在docker run运行容器时通过-p来发布这些端口,或通过-P参数来发布EXPOSE导出的所有端口

10.VOLUME指令

VOLUME指令:用于指定持久化目录

格式:
VOLUME ["/path/to/dir"] 示例:
VOLUME ["/data"]
VOLUME ["/var/www","/var/log/apache2","/etc/apache2"] 温馨提示:一个卷可以存在于一个或多个容器的指定目录,该目录可以绕过联合文件系统,并具有以下功能:
1.卷可以容器间共享和重用
2.容器并不一定要和其它容器共享卷
3.修改卷后会立即生效
4.对卷的修改不会对镜像产生影响
5.卷会一直存在,直到没有任何容器在使用它

11.USER指令

USER指令:指定运行容器时的用户名或UID。后续的RUN也会使用指定用户。使用USER指定用户时,可以使用用户名、UID或GID,或是两者的组合。当服务不需要管理员权限时,可以通过该命令指定运行用户,并且可以在之前创建所需要的用户

格式:
USER user
USER user:group
USER uid
USER uid:gid
USER user:gid
USER uid:group 示例:
USER www 温馨提示: 使用USER指定用户后,Dockerfile中其后的命令RUN、CMD、ENTRYPOINT都将使用该用户。镜像构建完成后,通过docker run运行容器时,可能通过-u参数来覆盖所指定的用户

12.ARG指令

ARG指令:用于指定传递给构建运行时的变量

格式:
ARG <name> [-<default value>] 示例:
ARG site
ARG build_user=www

13.ONBUILD指令

ONBUILD指令:用于设置镜像触发器

格式:
ONBUILD [INSTRUCTION] 示例:
ONBUILD ADD . /app/src
ONBUILD RUN /usr/local/bin/python-build --dir /app/src 温馨提示:当所构建的镜像被用做其它镜像的基础镜像,该镜像中的触发器将会被触发

14.LABEL指令

LABEL指令:用于镜像添加元数据

格式:
LABEL <key>=<value> <key>=<value> <key>=<value> ... 示例:
LABEL version="1.0" description="这是一个Web服务器" by="IT记录" 温馨提示:使用LABEL指定元数据时,一条LABEL指令可以指定一条或多条元数据,指定多条元数据时不同元数据之间通过空格分隔。推荐将所有的元数据通过一条LABEL指令指定,以免生成过多的中间镜像

小实例

# This my first nginx Dockerfile
# Version 1.0 # Base images 基础镜像
FROM centos:centos7.5.1804 #MAINTAINER 维护者信息
LABEL maintainer="inspur_lyx@hotmail.com" #ENV 设置环境变量
ENV PATH /usr/local/nginx/sbin:$PATH #ADD 文件放在当前目录下,拷过去会自动解压
#ADD nginx-1.8.1.tar.gz /usr/local
#ADD epel-release-latest-7.noarch.rpm /usr/local/ #RUN 执行以下命令
RUN yum -y install epel-release
RUN yum install -y wget lftp gcc gcc-c++ make openssl-devel pcre-devel pcre && yum clean all
RUN useradd -s /sbin/nologin -M www
RUN wget -O nginx-1.8.1.tar.gz "http://nginx.org/download/nginx-1.8.1.tar.gz"
RUN tar xf nginx-1.8.1.tar.gz -C /usr/local/ #WORKDIR 相当于cd
WORKDIR /usr/local/nginx-1.8.1 RUN ./configure --prefix=/usr/local/nginx --user=www --group=www --with-http_ssl_module --with-pcre && make && make install RUN echo "daemon off;" >> /etc/nginx.conf #EXPOSE 映射端口
EXPOSE 80 #容器启动时执行命令
CMD ["nginx","-g","daemon off;"]

另一小实例

# This my first django Dockerfile
# Version 1.0 # Base images 基础镜像
FROM centos:centos7.5.1804 #MAINTAINER 维护者信息
LABEL maintainer="inspur_lyx@hotmail.com" #ENV 设置环境变量
ENV LANG en_US.UTF-8
ENV LC_ALL en_US.UTF-8 #RUN 执行以下命令
RUN curl -so /etc/yum.repos.d/Centos-7.repo http://mirrors.aliyun.com/repo/Centos-7.repo
RUN yum install -y python36 python3-devel gcc pcre-devel zlib-devel make net-tools #工作目录
WORKDIR /opt/myblog #拷贝文件至工作目录
COPY . . #安装nginx
RUN tar -zxf nginx-1.13.7.tar.gz -C /opt && cd /opt/nginx-1.13.7 && ./configure --prefix=/usr/local/nginx \
&& make && make install && ln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx RUN cp myblog.conf /usr/local/nginx/conf/myblog.conf #安装依赖的插件
RUN pip3 install -i http://mirrors.aliyun.com/pypi/simple/ --trusted-host mirrors.aliyun.com -r requirements.txt RUN chmod +x run.sh && rm -rf ~/.cache/pip #EXPOSE 映射端口
EXPOSE 8002 #容器启动时执行命令
CMD ["./run.sh"]

执行构建:

docker build . -t myblog:v1 -f Dockerfile

Docker之Dockerfile文件的更多相关文章

  1. Docker(十)-Docker创建DockerFile文件

    制作Docker image 有两种方式: 使用 Docker container,直接构建容器,再导出成 image 使用. 是使用 Dockerfile,将所有动作写在文件中,再 build 成 ...

  2. Centos7安装Docker 基于Dockerfile 搭建httpd运行环境

    Centos7安装Docker 基于Dockerfile 搭建httpd运行环境 docker docker搭建 docker build 本文档完成目标内容如下 使用Docker搭建http服务器一 ...

  3. 【Docker】(6)---Dockerfile文件

    springboot项目打包镜像中的Dockerfile文件 在讲Dockerfile文件之前应该先讲下maven的一个插件叫:dockerfile-maven-plugin.他们是组合一起用的 一. ...

  4. ASP.NET CORE做的网站运行在docker上(不用dockerfile文件部署)

    按网上的做法用dockerfile文件是可以弄得出来的,http://www.docker.org.cn/article/119.html, 不过我想把网站文件放在外面硬盘目录,再映射进去,这样只要在 ...

  5. Docker定制容器镜像(利用Dockerfile文件)

    1.创建Dockerfile文件 新建一个目录,在里面新建一个dockerfile文件(新建一个的目录,主要是为了和以防和其它dockerfile混乱 ) [root@docker01 myfiles ...

  6. Docker镜像构建文件Dockerfile及相关命令介绍

    使用docker build命令或使用Docker Hub的自动构建功能构建Docker镜像时,都需要一个Dockerfile文件.Dockerfile文件是一个由一系列构建指令组成的文本文件,doc ...

  7. docker Dockerfile文件的编写部分命令

    镜像的构建过程:编写dockerfile文件,执行docker build 进行构建镜像,最后docker run 运行容器镜像实例. docker build -t mycentos:1.01 . ...

  8. dockerfile定制docker的脚本文件

    Dockerfile文件详解 #指定操作系统 FROM scratch #制作base image 基础镜像,尽量使用官方的image作为base image FROM centos #使用base ...

  9. Docker学习笔记-Dockerfile文件详解

    什么是Dockerfile? Docker中有个非常重要的概念叫做--镜像(Image).Docker 镜像是一个特殊的文件系统,除了提供容器运行时所需的程序.库.资源.配置等文件外,还包含了一些为运 ...

随机推荐

  1. Cloudera Manager添加主机节点

    为了监控方便,想把研发环境中的主机节点都纳入Cloudera Manager的管理中,这样在遇到问题时可方便的查看主机的硬件资源情况. 添加主机节点有多种方式,由于我是离线工作,所以选择rpm包的方式 ...

  2. UNDO表空间切换步骤

    1.新建UNDO表空间 create undo tablespace UNDOTBS2 datafile '/data01/testdb/undotbs01.dbf' size 1G; alter d ...

  3. Python入门之修改jupyter启动目录

    [导读]在给大家分享知识的过程中,我们也会分享一些小技巧,能够帮助大家在学习过程中有更好的体验.之前我们给大家分享了anaconda安装教程以及jupyter notebook使用方法,今天我们为大家 ...

  4. 前端面试之JavaScript中的闭包!

    前端面试之JavaScript中的闭包! 闭包 闭包( closure )指有权访问另一个函数作用域中变量的函数. ----- JavaScript 高级程序设计 闭包其实可以理解为是一个函数 简单理 ...

  5. vue.esm.js?efeb:628 [Vue warn]: Invalid prop: type check failed for prop "defaultActive". Expected String with value "0", got Number with value 0.

    vue.esm.js?efeb:628 [Vue warn]: Invalid prop: type check failed for prop "defaultActive". ...

  6. 览器全面禁用三方 Cookie 全栈前端精选 4月16日

    览器全面禁用三方 Cookie 全栈前端精选 4月16日

  7. token的分层图如下

    基于 token 的多平台身份认证架构设

  8. 防sql注入之参数绑定 SQL Injection Attacks and Defense 预处理语句与存储过程

    http://php.net/manual/zh/pdo.prepared-statements.php 预处理语句与存储过程 很多更成熟的数据库都支持预处理语句的概念.什么是预处理语句?可以把它看作 ...

  9. 理解和运用 ClassLoader 该篇文章就够了

    定义 根据<深入理解Java虚拟机>提到"通过一个类的全限定名(packageName.ClassName)来获取描述此类的二进制字节(class文件字节)这个动作的代码模块就叫 ...

  10. QT之——QTableWidget拖拽单元格并替换内容(进阶)

    所需待重写函数: [virtual] bool QObject::eventFilter(QObject *watched, QEvent *event); /* * Filters events i ...