Dockerfile

目录

dockerfile是什么

基本结构

docekrfile的基础知识

DockerFile体系结构

指令

FROM

LABEL MAINTAINER

RUN

CMD

EXPOSE

ENV

ADD

COPY

ENTRYPOINT

VOLUME

USER

WORKDIR

ONBUILD

用 Dockerfile 定制镜像

编写脚本

编写Dockerfile

制作镜像

上传镜像


dockerfile是什么

dockerfile是用来共建docker镜像的构建文件,是由一系列命令和参数构成的脚本

构建的三步骤:

  1. 编写dockerfile文件

  2. docker builc

  3. docekr rur

基本结构

Dockerfile 是一个文本格式的配置文件,用户可以使用 Dockerfile 快速创建自定义镜像。

Dockerfile 由一行行命令语句组成,并且支持以 # 开头的注释行。

Docker分为四部分:

  • 基础镜像信息

  • 维护者信息

  • 镜像操作指令

  • 容器启动时默认要执行的指令

docekrfile的基础知识

docekrfile中的指令需要满足如下的规则

指令的规则:

  1. 每条保留的指令都必须是大写字母且后面要跟随至少一个参数

  2. 指令按照从上到下的顺序执行

  3. #表示注释

  4. 每条指令都会创建一个新的镜像层,并对镜像提交

DockerFile体系结构

指令说明
FROM基础镜像,当前的镜像是基于哪个镜像的,意味着继承
LABEL MAINTAINER镜像维护者的姓名和邮箱地址
RUN容器构建时需要运行的命令
CMD指定一个容器启动时要运行的命令,Dockerfile中可以有多个CMD指令,但只有最后一个生效,CMD会被docker run之后的参数替换
EXPOSE当前容器对外暴露的端口
ENV用来在构建镜像过程中设置环境变量
ADD将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar压缩包
COPY类似ADD,拷贝文件和目录到镜像中。 将从构建上下文目录中<源路径>的文件/目录复制到新的一层的镜像内的<目标路径>位置 COPY src dest COPY [“src”,“dest”]
ENTRYPOINT指定一个容器启动时要运行的命令ENTRRYPOINT和CMD一样,都是在指定容器启动程序及参数
VOLUME容器数据卷,用于数据保存和持久化工作
USER指定运行容器时的用户名或UID,后续的RUN也会使用指定用户。
WORKDIR指定在创建容器后,终端默认登录的进来工作目录
ONBUILD当构建一个被继承的Dockerfile时运行命令,父镜像在被子继承后父镜像的onbuild被触发

指令

FROM

格式为`FROM <image>`或`FROM <image>:<tag>`。
FROM <镜像>                  //FROM必须是Docker非空开头的第一行

第一条指令必须为FROM指令。并且,如果在同一个Dockerfile中创建多个镜像时,可以使用多个FROM指令(每个镜像一次)。

LABEL MAINTAINER

LABEL MAINTAINER: 镜像维护者的姓名和邮箱地址

LABEL MAINTAINER [维护者] [邮箱地址]     

RUN

RUN 格式为RUN <command>RUN ["executable","param1","param2"]

前者将在shell终端中运行命令,即/bin/sh -c;后者则使用exec执行。指定使用其他终端可以通过第二种方式实现,例如:

RUN ["/bin/bash","-c","echo hello"]

每条RUN指令将在当前镜像基础上执行指定命令,并提交为新的镜像。

RUN 分两种命令执行方式:
shell执行,即/bin/sh
格式:
    RUN <command>
​
exec执行
格式:
    RUN [“executable”,“param1”,“param2”]
    要注意的时,executable时命令,后面的param是参数
注:
  RUN指令创建的中间镜像会被缓存,并会在下次构建中使用。如果不想使用这些缓存镜像,可以在构建时指定--no-cache参数,如:docker build --no-cache   

当命令较长时可以使用 \ 来换行,例如:

RUN echo "hello world\nhello tom" > /tmp/abc && \
    cat /tmp/abc

CMD

CMD三种格式:

#第一种时shell这种执行方式和写法
CMD command param1 paraml2
#第二中时可执行文件加上参数的形式
CMD [“executable”,“param1”,“param2”]
执行过程比较明确。第一种格式实际上在运行的过程中也会自动转换成第二种格式运行,并且默认可执行文件是sh。
#第三种是ENTRYPOINT指令指定的程序提供默认参数
CMD ["<param1>","<param2>",...]

CMD用于指定启动容器时默认要执行的命令,每个Dockerfile只能有一条CMD命令。如果指定了多条命令,只有最后一条会被执行。

如果用户启动容器时指定了运行的命令,则会覆盖掉CMD指定的命令。

EXPOSE

格式为:
EXPOSE <port> [<port>...]
 
eg:
EXPOSE 22 80 8443

EXPOSE用于告诉Docker服务器容器暴露的端口号,供互联系统使用。

在启动容器时通过-P,Docker主机会自动分配一个端口转发到指定的端口;使用-p则可以具体指定哪个本地端口映射过来。

ENV

ENV :设置环境变量,定义了环境变量,那么在后续的指令中,就可以使用这个环境变量。

ENV <key> <value>
ENV <key1>=<value1> <key2>=<value2>...

ADD

ADD :ADD 指令和 COPY 的使用格类似; ADD还支持使用TAR文件和URL路径,并且会将tar压缩文件(gzip, bzip2以及 xz格式)解压缩,如果指定的是url,会从指定的url下载文件放到目录中( 如果url下载的文件为tar文件,则不会展开)。

ADD [--chown=<user>:<group>] <src>... <dest>
ADD [--chown=<user>:<group>] ["<src>",... "<dest>"]
    
eg:
ADD /data/src/nginx-1.14.0.tar.gz /data/src/

# 构建镜像
docker build -t nginx:v1.1  .

# 创建容器
docker run --rm --name nginx -it  nginx:v1.1  ls /data/src

# 我们可以发现已经解压了nginx-1.14.0.tar.gz文件

COPY

COPY:复制指令,从上下文目录中复制文件或者目录到容器里指定路径。

COPY [--chown=<user>:<group>] <src>... <dest>
COPY [--chown=<user>:<group>] ["<src>",... "<dest>"]

ENTRYPOINT

类似CMD指令的功能,用于为容器指定默认运行程序,从而使得容器像是一个单独的可执行程序。

在写Dockerfile时, ENTRYPOINT或者CMD指令会自动覆盖之前的ENTRYPOINT或者CMD指令。即ENTRYPOINT或者CMD指令只能写一条,如果写了多条,那么,ENTRYPOINT或者CMD都只有最后一条生效。

在Docker镜像运行时, 用户也可以在命令行指定具体命令, 覆盖在Dockerfile里的命令。

与CMD不同的是,由ENTRYPOINT启动的程序不会被docker run命令行指定的参数所覆盖,而且,这些命令行参数会被当作参数传递给ENTRYPOINT指令指定的程序,不过,docker run命令的--entrypoint选项的参数可覆盖ENTRYPOINT指令指定的程序。

语法:
ENTRYPOINT ["executable","param1","param2"]
ENTRYPOINT command param1 param2(在shell中执行)

第一种就是可执行文件加参数。与CMD指令一样,ENTRYPOINT也更加推荐使用exec格式。

第二种就是shell格式。

案例:

FROM ubuntu 
RUN apt-get update && apt-get install -y curl && rm -rf /var/lib/apt/lists/* 
ENTRYPOINT ["curl", "-s", "http://ip.cn"]

# 将其构建成镜像ubuntu:v1.2,下面我们创建并启动容器:
docker run -it ubuntu:v1.2

# 将会在控制台输出我们相应的公网IP信息!
# 此时,如果我们还需要获取HTTP头信息时,我们可以这样:
docker run -it ubuntu:v1.2 -i

VOLUME

VOLUME :定义匿名数据卷。在启动容器时忘记挂载数据卷,会自动挂载到匿名卷。

作用:

  • 避免重要的数据,因容器重启而丢失,这是非常致命的。(容器使用的是AUFS,这种文件系统不能持久化数据,当容器关闭后,所有的更改都会丢失。)

  • 避免容器不断变大。

格式:    
VOLUME ["/path/to/dir"] 

示例:   
VOLUME ["/data"]    
VOLUME ["/var/www", "/var/log/apache2","/etc/apache2"] 

USER

USER :用于指定执行后续命令的用户和用户组,这边只是切换后续命令执行的用户(用户和用户组必须提前已经存在)。

格式:
  USER user
  USER user:group
  USER uid
  USER uid:gid
  USER user:gid
  USER uid:group

WORKDIR

WORKDIR : 指定工作目录。用 WORKDIR 指定的工作目录,会在构建镜像的每一层中都存在。(WORKDIR 指定的工作目录,必须是提前创建好的)。

WORKDIR <工作目录路径>

eg:
    WORKDIR /a  (这时工作目录为/a)
    WORKDIR b  (这时工作目录为/a/b)
    WORKDIR c  (这时工作目录为/a/b/c)

ONBUILD

ONBUILD :用于延迟构建命令的执行。简单的说,就是 Dockerfile 里用 ONBUILD 指定的命令,在本次构建镜像的过程中不会执行(假设镜像为 test-build)。当有新的 Dockerfile 使用了之前构建的镜像 FROM test-build ,这时执行新镜像的 Dockerfile 构建时候,会执行 test-build 的 Dockerfile 里的 ONBUILD 指定的命令。

ONBUILD <其它指令>
    
eg:
from ubuntu:16.04
WORKDIR /data
ONBUILD RUN mkdir test
# notes:
  当所构建的镜像被用做其它镜像的基础镜像时(比如用户的镜像需要从某为准备好的位置添加源代码,或者用户需要执行特定于构建镜像的环境的构建脚本),该镜像中的触发器将会被钥触发

用 Dockerfile 定制镜像

编写脚本

[root@localhost ~]# cd httpd
[root@localhost httpd]# ls
Dockerfile  files
[root@localhost httpd]# cd files/
[root@localhost files]# ls
apr-1.7.0.tar.gz  apr-util-1.6.1.tar.gz  httpd-2.4.54.tar.gz
[root@localhost files]# vim entrypoint.sh
#!/bin/bash

sed -i '^#/ServerName/s/#//g' /usr/local/apache/conf/httpd.conf

exec "$@"
    
[root@localhost files]# chmod +x entrypoint.sh 
[root@localhost files]# ll
total 11136
-rw-r--r--. 1 root root 1093896 Aug 30 09:39 apr-1.7.0.tar.gz
-rw-r--r--. 1 root root  554301 Aug 30 09:39 apr-util-1.6.1.tar.gz
-rwxr-xr-x. 1 root root      88 Aug 30 19:06 entrypoint.sh
-rw-r--r--. 1 root root 9743277 Aug 30 09:39 httpd-2.4.54.tar.gz

编写Dockerfile

[root@localhost ~]# vim Dockerfile
FROM centos

LABEL MAINTAINER "jiang 1919756426@qq.com"

EXPOSE 80 443
ADD files/* /usr/src/
ADD files/entrypoint.sh /

RUN useradd -r -M -s /sbin/nologin apache && \
    rm -rf /etc/yum.repos.d/* && \
    curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-vault-8.5.2111.repo  && \
    sed -i -e '/mirrors.cloud.aliyuncs.com/d' -e '/mirrors.aliyuncs.com/d' /etc/yum.repos.d/CentOS-Base.repo  && \
    yum clean all && \
    yum -y install openssl-devel pcre-devel expat-devel libtool make gcc gcc-c++ && \
    cd /usr/src/apr-1.7.0 && \
    sed -i '/$RM "$cfgfile"/d' configure && \
    ./configure --prefix=/usr/local/apr && \
    make && \
    make install && \
    cd ../apr-util-1.6.1/ && \
    ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr && \
    make && \
    make install && \
    cd ../httpd-2.4.54/ && \
    ./configure --prefix=/usr/local/apache \
        --enable-so \
        --enable-ssl \
        --enable-cgi \
        --enable-rewrite \
        --with-zlib \
        --with-pcre \
        --with-apr=/usr/local/apr \
        --with-apr-util=/usr/local/apr-util/ \
        --enable-modules=most \
        --enable-mpms-shared=all \
        --with-mpm=prefork && \
    make && \
    make install && \
    yum clean all && \
    yum -y remove gcc gcc-c++ make && \
    rm -rf /var/log/* /var/cache/* /usr/src/*

WORKDIR /usr/local/apache
CMD ["/usr/local/apache/bin/httpd","-D","FOREGROUND"]
ENTRYPOINT ["/bin/bash","/entrypoint.sh"]

制作镜像

[root@localhost httpd]# podman build -t httpd:v0.5 .
STEP 1/9: FROM centos
STEP 2/9: LABEL MAINTAINER "jiang 1919756426@qq.com"
--> Using cache 926336258cd4bc6ff0417b64767e092c3e615d8d822b5f8b53ba21c9b9ef47a6
--> 926336258cd
STEP 3/9: EXPOSE 80 443
--> fc6ffe3a218
STEP 4/9: ADD files/* /usr/src/
--> a4d903caf7c
STEP 5/9: ADD files/entrypoint.sh /
--> 9e71b4026b9

...................................

Complete!
--> 1db27ce9d11
STEP 7/9: WORKDIR /usr/local/apache
--> bbb46bfdfdd
STEP 8/9: CMD ["/usr/local/apache/bin/httpd","-D","FOREGROUND"]
--> 547666c014f
STEP 9/9: ENTRYPOINT ["/bin/bash","/entrypoint.sh"]    
COMMIT httpd:v0.5
--> a59f2a018fb
Successfully tagged localhost/httpd:v0.5
a59f2a018fbfba628310b30faea0e14f1c329bc4911102cf1a317115c1bcec4e

[root@localhost httpd]# podman images
REPOSITORY                  TAG         IMAGE ID      CREATED        SIZE
localhost/httpd             v0.5        a59f2a018fbf  3 minutes ago  405 MB

[root@localhost httpd]# podman tag localhost/httpd:v0.5 docker.io/1919756426/myhttpd:v0.1
[root@localhost httpd]# podman images
REPOSITORY                    TAG         IMAGE ID      CREATED        SIZE
docker.io/1919756426/myhttpd  v0.1        a59f2a018fbf  9 minutes ago  405 MB

[root@localhost httpd]# podman run -d --name web4 -P myhttpd:v0.1
c28c2e38cb49ea7b5f80d609cbcabac97aec30047420acdfb57c58fed076fffa
[root@localhost httpd]# podman ps
CONTAINER ID  IMAGE                              COMMAND               CREATED        STATUS            PORTS                                          NAMES
f2730545befa  docker.io/library/httpd:latest     httpd-foreground      8 hours ago    Up 8 hours ago    0.0.0.0:45329->80/tcp                          web3
c28c2e38cb49  docker.io/1919756426/myhttpd:v0.1  /usr/local/apache...  3 seconds ago  Up 3 seconds ago  0.0.0.0:46505->443/tcp, 0.0.0.0:46153->80/tcp  web4
[root@localhost httpd]# podman inspect -l |grep -i ipaddr
               "IPAddress": "10.88.0.11",
                         "IPAddress": "10.88.0.11",
[root@localhost httpd]# curl 10.88.0.11
<html><body><h1>It works!</h1></body></html>

上传镜像

[root@localhost ~]# podman login docker.io
Authenticating with existing credentials for docker.io
Existing credentials are valid. Already logged in to docker.io
[root@localhost ~]# podman push docker.io/1919756426/myhttpd:v0.1
Getting image source signatures
Copying blob 099f22a15c81 done  
Copying blob 1d5b826d3d5a skipped: already exists  
Copying blob 9ac38a6a7b19 skipped: already exists  
Copying blob 2653d992f4ef skipped: already exists  
Copying config a59f2a018f done  
Writing manifest to image destination
Storing signatures

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值