zoukankan      html  css  js  c++  java
  • Docker之Dockerfile文件

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

    1587027387301

    Dockerfile常用指令

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

    1587046122200

    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
    
    
  • 相关阅读:
    win11系统无法解决的死结
    python多线程2线程应用
    python多线程3线程同步
    python多线程3.1同步测试例子
    python多线程1线程创建
    最近总是淡淡的····
    ASP.NET MVC 中如何实现基于角色的权限控制
    【转】Visual C++ ADO数据库编程入门
    【转】Windows窗体消息汇总
    【转】数据库设计中的14个技巧
  • 原文地址:https://www.cnblogs.com/Heroge/p/12736376.html
Copyright © 2011-2022 走看看