zoukankan      html  css  js  c++  java
  • Docker-dockerfile文件

    1.1 什么是DockerFile

    dockerfile是用来构建Docker镜像的构建文件,是由一系列命令和参数构成的脚本。
    构建步骤:

    1、编写一个dockerFile文件。

    2、docker build 构建成为一个镜像。

    3、docker run运行镜像

    4、docker push 发布镜像(DockerHub、阿里云镜像仓库)

    查看仓库的centOS: https://hub.docker.com/_/centos

    点击镜像: https://github.com/CentOS/sig-cloud-instance-images/blob/b2d195220e1c5b181427c3172829c23ab9cd27eb/docker/Dockerfile

    小结: 很多官方镜像都是基础包,很多功能没有,通常我们自己会搭建自己的镜像!!!

    1.2 DockerFile构建过程

    1、基础知识

    • 每条保留字指令都必须为大写字母且后面要跟随至少一个参数。
    • 指令按照从上到下,顺序执行
    • #表示注释。
    • 每条指令都会创建一个新的镜像层,并且对镜像进行提交。

    2、步骤流程

    • docker从基础镜像运行一个容器,执行一条指令并对容器做出修改。
    • 执行类似 docker commit 的操作提交一个新的镜像层。
    • Docker再基于刚提交的镜像运行一个新容器。
    • 执行dockerfile中的下一条指令直到所有指令都执行完成!

    3、具体说明

    dockerfile是面向开发的,以后要发布项目,做镜像,就需要编写dockerfile文件。

    DockerFile: 构建文件,定义了一切步骤,源代码!!!

    DockerImages:在DockerFile 定义了一个文件之后,Docker build 时会产生一个Docker镜像,当运行Docker 镜像时,会真正开始提供服务。

    Docker容器:容器就是镜像运行起来的提供服务器!!

    1.3 DockerFile指令

    常用指令

    FROM  # 基础镜像,一切从这里开始构建。
    MAINTAINER  # 镜像维护者的姓名混合邮箱地址。
    RUN  # 容器构建时需要运行的命令。
    ADD  # 步骤,tomcat镜像,这个tomact压缩包!!!添加内容。
    WORKDIR  # 镜像的工作目录。
    VOLUME # 容器数据卷,用于数据保存和持久化工作,挂载的目录。
    EXPOSE # 保留端口配置
    CMD # 指定一个容器启动时要运行的命令,只有最后一个会生效,可被替代!!
    ENTRYPOINT # 指定一个容器启动时要运行的命令!和CMD一样,可以追加命令!!!
    ONBUILD # 当构建一个被继承的DockerFile时运行命令,父镜像在被子镜像继承后,父镜像的ONBUILD被触发。
    COPY # 类似ADD,拷贝文件和目录到镜像中!
    ENV # 构建的时候设置环境变量。
    

    1.4 案例说明

    Docker Hub 中99% 的镜像都是通过在base镜像(Scratch)中安装和配置需要的软件构建出来的。

    自定义一个CentOS镜像

    1、编写DockerFlie文件

    查看官方默认的CentOS镜像的情况

    需求实现: 登陆后的默认路径/home、安装vim编辑器、安装查看网络配置ifconfig

    [root@Linux home]# mkdir dockerfile-test
    [root@Linux home]# cd dockerfile-test/
    [root@Linux dockerfile-test]# vim mydockerfile-centos # 编辑文件
    [root@Linux dockerfile-test]# ls
    mydockerfile-centos
    [root@Linux dockerfile-test]# cat mydockerfile-centos 
    FROM centos
    MAINTAINER guardwhy<hxy1625309592@aliyun.com>
    
    ENV MYPATH /home
    WORKDIR $MYPATH
    
    RUN yum -y install vim
    RUN yum -y install net-tools
    RUN yum -y install gcc
    
    EXPOSE 80
    
    CMD echo $MYPATH
    CMD echo "----------end--------"
    CMD /bin/bash
    [root@Linux dockerfile-test]# 
    

    2、构建镜像

    docker build -f mydockerfile-centos -t centos:7 .
    


    3、运行新镜像

    docker run -it centos:7
    

    可以看到,新镜像已经支持 vim/ifconfig/gcc的命令,安装拓展成功!!!

    4、列出镜像地的变更历史

    基本语法:docker history 镜像名

    docker history 70aba9c80bd4
    

    1.5 CMD 和 ENTRYPOINT 的区别

    CMD:指定这个容器的时候要运行的命令,只有最后一个会生效,可被替代。

    ENTRYPOINT:指定这个容器启动的时候要运行的命令,可以追加命令!!

    测试CMD

    # 1、构建dockerfile
    [root@Linux dockerfile-test]# vim dockerfile-cmd-test
    [root@Linux dockerfile-test]# cat dockerfile-cmd-test 
    FROM centos
    CMD [ "ls", "-a" ]
    
    # 2、构建镜像
    [root@Linux dockerfile-test]# docker build -f dockerfile-cmd-test -t cmdtest .
    Sending build context to Docker daemon  3.072kB
    Step 1/2 : FROM centos
     ---> 300e315adb2f
    Step 2/2 : CMD [ "ls", "-a" ]
     ---> Running in 92d90f5cf57e
    Removing intermediate container 92d90f5cf57e
     ---> 31c35ef26b4e
    Successfully built 31c35ef26b4e
    Successfully tagged cmdtest:latest
    
    # 3、run运行,发现ls -a 命令生效
    [root@Linux dockerfile-test]# docker run 31c35ef26b4e
    .
    ..
    .dockerenv
    bin
    dev
    etc
    home
    # 4、希望用 -l 列表展示信息,需要加上 -l参数
    [root@Linux dockerfile-test]# docker run 31c35ef26b4e -l
    docker: Error response from daemon: OCI runtime create failed: container_linux.go:380: starting container process caused: exec: "-l": executable file not found in $PATH: unknown.
    ERRO[0000] error waiting for container: context canceled 
    
    # 5、问题:我们可以看到可执行文件找不到的报错,executable file not found。跟在镜像名后面的是 command,运行时会替换 CMD 的默认值。
    # 因此这里的 -l 替换了原来的 CMD,而不是添加在原来的 ls -a 后面。而 -l 根本不是命令,所以自然找不到。
    
    # 6、如果希望加入 -l 这参数,就必须重新完整的输入这个命令:
    [root@Linux dockerfile-test]# docker run 31c35ef26b4e ls -al
    total 60
    drwxr-xr-x.   1 root root 4096 Jun 11 02:36 .
    drwxr-xr-x.   1 root root 4096 Jun 11 02:36 ..
    -rwxr-xr-x.   1 root root    0 Jun 11 02:36 .dockerenv
    lrwxrwxrwx.   1 root root    7 Nov  3  2020 bin -> usr/bin
    drwxr-xr-x.   5 root root  340 Jun 11 02:36 dev
    drwxr-xr-x.   1 root root 4096 Jun 11 02:36 etc
    ......
    [root@Linux dockerfile-test]# 
    

    测试ENTRYPOINT

    # 1、构建dockerfile
    [root@Linux dockerfile-test]# vim dockerfile-entrypoint-test
    [root@Linux dockerfile-test]# cat dockerfile-entrypoint-test 
    FROM centos
    ENTRYPOINT [ "ls", "-a" ]
    
    # 2、构建镜像
    [root@Linux dockerfile-test]# docker build -f dockerfile-entrypoint-test -t entrypoint-test .
    Sending build context to Docker daemon  4.096kB
    Step 1/2 : FROM centos
     ---> 300e315adb2f
    Step 2/2 : ENTRYPOINT [ "ls", "-a" ]
     ---> Running in a1f66d11b94c
    Removing intermediate container a1f66d11b94c
     ---> 5265bb79246a
    Successfully built 5265bb79246a
    Successfully tagged entrypoint-test:latest
    
    # 3、run运行,发现ls -a 命令生效
    [root@Linux dockerfile-test]# docker run 5265bb79246a
    .
    ..
    .dockerenv
    bin
    dev
    etc
    home
    lib
    lib64
    ...
    # 4、测试-l参数,发现可以直接使用,这里就是一种追加,可以明显的知道CMD和ENTRYPOINT的区别
    [root@Linux dockerfile-test]# docker run 5265bb79246a -l
    total 60
    drwxr-xr-x.   1 root root 4096 Jun 11 02:43 .
    drwxr-xr-x.   1 root root 4096 Jun 11 02:43 ..
    -rwxr-xr-x.   1 root root    0 Jun 11 02:43 .dockerenv
    lrwxrwxrwx.   1 root root    7 Nov  3  2020 bin -> usr/bin
    drwxr-xr-x.   5 root root  340 Jun 11 02:43 dev
    drwxr-xr-x.   1 root root 4096 Jun 11 02:43 etc
    drwxr-xr-x.   2 root root 4096 Nov  3  2020 home
    lrwxrwxrwx.   1 root root    7 Nov  3  2020 lib -> usr/lib
    lrwxrwxrwx.   1 root root    9 Nov  3  2020 lib64 -> usr/lib64
    .....
    [root@Linux dockerfile-test]# 
    

    1.6 自定义镜像 tomcat

    1、创建文件夹,执行以下命令: mkdir -p guardwhy/tomcat

    2、在上述目录下创建新文件:touch readme.txt

    3、将 jdktomcat 安装的压缩包拷贝进上一步目录。

    4、在guardwhy/tomcat目录下新建一个Dockerfile文件

    注意: 官方命名为Dockerfile,build会自动寻找这个文件,就不需要-f 指定了!!!

    # vim Dockerfile
    FROM centos
    MAINTAINER guardwhy<hxy1625309592@aliyun.com>
    
    #把宿主机当前上下文的readme.txt拷贝到容器/usr/local/路径下
    COPY readme.txt /usr/local/readme.txt
    #把java与tomcat添加到容器中
    ADD jdk-8u261-linux-x64.tar.gz /usr/local/
    ADD apache-tomcat-9.0.46.tar.gz /usr/local/
    
    #安装vim编辑器
    RUN yum -y install vim
    #设置工作访问时候的WORKDIR路径,登录落脚点
    ENV MYPATH /usr/local
    WORKDIR $MYPATH
    
    #配置java与tomcat环境变量
    ENV JAVA_HOME /usr/local/jdk1.8.0_261
    ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar
    ENV CATALINA_HOME /usr/local/apache-tomcat-9.0.46
    ENV CATALINA_BASE /usr/local/apache-tomcat-9.0.46
    ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
    
    #容器运行时监听的端口
    EXPOSE 8080
    
    #启动时运行tomcat
    CMD /usr/local/apache-tomcat-9.0.46/bin/startup.sh && tail -F /usr/local/apache-tomcat-9.0.46/bin/logs/catalina.out
    

    5、构建镜像,执行命令 docker build -t diytomcat .

    [root@Linux tomcat]# docker build -t diytomcat .
    Sending build context to Docker daemon  154.6MB
    Step 1/15 : FROM centos
     ---> 300e315adb2f
    Step 2/15 : MAINTAINER guardwhy<hxy1625309592@aliyun.com>
     ---> Using cache
     ---> 2d8a3df8c6fb
    Dependencies resolved.
    ================================================================================
     Package             Arch        Version                   Repository      Size
    ================================================================================
    Installing:
     vim-enhanced        x86_64      2:8.0.1763-15.el8         appstream      1.4 M
    Installing dependencies:
     gpm-libs            x86_64      1.20.7-17.el8             appstream       39 k
     vim-common          x86_64      2:8.0.1763-15.el8         appstream      6.3 M
     vim-filesystem      noarch      2:8.0.1763-15.el8         appstream       48 k
     which               x86_64      2.21-12.el8               baseos          49 k
    
    Transaction Summary
    ================================================================================
    Install  5 Packages
    
    Total download size: 7.8 M
    Installed size: 30 M
    Downloading Packages:
    (1/5): gpm-libs-1.20.7-17.el8.x86_64.rpm        132 kB/s |  39 kB     00:00    
    (2/5): vim-enhanced-8.0.1763-15.el8.x86_64.rpm  2.9 MB/s | 1.4 MB     00:00    
    (3/5): vim-filesystem-8.0.1763-15.el8.noarch.rp 233 kB/s |  48 kB     00:00    
    (4/5): vim-common-8.0.1763-15.el8.x86_64.rpm    9.0 MB/s | 6.3 MB     00:00    
    (5/5): which-2.21-12.el8.x86_64.rpm             205 kB/s |  49 kB     00:00    
    --------------------------------------------------------------------------------
    Total                                           4.7 MB/s | 7.8 MB     00:01     
    warning: /var/cache/dnf/appstream-02e86d1c976ab532/packages/gpm-libs-1.20.7-17.el8.x86_64.rpm: Header V3 RSA/SHA256 Signature, key ID 8483c65d: NOKEY
    CentOS Linux 8 - AppStream                      1.6 MB/s | 1.6 kB     00:00    
    Importing GPG key 0x8483C65D:
     Userid     : "CentOS (CentOS Official Signing Key) <security@centos.org>"
     Fingerprint: 99DB 70FA E1D7 CE22 7FB6 4882 05B5 55B3 8483 C65D
     From       : /etc/pki/rpm-gpg/RPM-GPG-KEY-centosofficial
    Complete!
    Successfully built ecc82f059377
    Successfully tagged diytomcat:latest
    [root@Linux tomcat]# docker images
    REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
    diytomcat           latest              ecc82f059377        4 minutes ago       638MB
    centos              7                   70aba9c80bd4        18 hours ago        451MB
    centos              latest              300e315adb2f        6 months ago        209MB
    [root@Linux tomcat]# 
    

    6、运行启动自定义镜像!

    docker run 
    -d -p 9090:8080 --name mydiytomcat 
    -v /home/guardwhy/tomcat/test:/usr/local/apache-tomcat-9.0.46/webapps/test 
    -v /home/guardwhy/tomcat/tomcat9logs/:/usr/local/apache-tomcat-9.0.46/logs 
    --privileged=true diytomcat
    


    7、开启端口

    开启8080:9000端口,打开防火墙。

    firewall-cmd --zone=public --add-port=8080/tcp --permanent
    firewall-cmd --zone=public --add-port=9090/tcp --permanent
    firewall-cmd --reload
    

    查看所有开启的端口

    firewall-cmd --list-ports
    

    8、验证测试访问,链接访问: http://192.168.50.128:9090/

    9、网页发布测试

    创建WEB-INF文件夹,在文件夹中新建web.xml文件

    web.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
             version="4.0">
    </web-app>
    

    index.jsp

    <%@ page contentType="text/html;charset=UTF-8" language="java" %>
    <html>
    <head>
        <title>docker</title>
    </head>
    <body>
        <h3>hello,docker</h3>
        <%
            System.out.println("hello, dockerlogs");
        %>
    </body>
    </html>
    

    执行结果,点击链接: http://192.168.50.128:9090/test/

    10、查看日志

    [root@Linux tomcat]# ls
    apache-tomcat-9.0.46.tar.gz  Dockerfile  jdk-8u261-linux-x64.tar.gz  readme.txt  test  tomcat9logs
    [root@Linux tomcat]# cd tomcat9logs/
    [root@Linux tomcat9logs]# ls -l
    总用量 48
    -rw-r-----. 1 root root 16650 6月  11 16:51 catalina.2021-06-11.log
    -rw-r-----. 1 root root 16668 6月  11 16:57 catalina.out
    -rw-r-----. 1 root root     0 6月  11 16:18 host-manager.2021-06-11.log
    -rw-r-----. 1 root root   407 6月  11 16:18 localhost.2021-06-11.log
    -rw-r-----. 1 root root  1763 6月  11 16:57 localhost_access_log.2021-06-11.txt
    -rw-r-----. 1 root root     0 6月  11 16:18 manager.2021-06-11.log
    [root@Linux tomcat9logs]# 
    

    1.7 发布镜像到阿里云

    1、注册阿里云,登录阿里云服务

    2、找到容器镜像服务。

    3、创建命名空间

    4、创建镜像仓库


    5、点击进入这个镜像仓库,可以看到所有的信息

    操作指南

    1. 登录阿里云Docker Registry
    $ docker login --username=tb99****08_88 registry.cn-qingdao.aliyuncs.com
    用于登录的用户名为阿里云账号全名,密码为开通服务时设置的密码。
    
    您可以在访问凭证页面修改凭证密码。
    
    2. 从Registry中拉取镜像
    $ docker pull registry.cn-qingdao.aliyuncs.com/docker-guardwhy/java-test:[镜像版本号]
    3. 将镜像推送到Registry
    $ docker login --username=tb99****08_88 registry.cn-qingdao.aliyuncs.com
    $ docker tag [ImageId] registry.cn-qingdao.aliyuncs.com/docker-guardwhy/java-test:[镜像版本号]
    $ docker push registry.cn-qingdao.aliyuncs.com/docker-guardwhy/java-test:[镜像版本号]
    请根据实际镜像信息替换示例中的[ImageId]和[镜像版本号]参数。
    
    4. 选择合适的镜像仓库地址
    从ECS推送镜像时,可以选择使用镜像仓库内网地址。推送速度将得到提升并且将不会损耗您的公网流量。
    
    如果您使用的机器位于VPC网络,请使用 registry-vpc.cn-qingdao.aliyuncs.com 作为Registry的域名登录。
    
    5. 示例
    使用"docker tag"命令重命名镜像,并将它通过专有网络地址推送至Registry。
    
    $ docker images
    REPOSITORY                                                         TAG                 IMAGE ID            CREATED             VIRTUAL SIZE
    registry.aliyuncs.com/acs/agent                                    0.7-dfb6816         37bb9c63c8b2        7 days ago          37.89 MB
    $ docker tag 37bb9c63c8b2 registry-vpc.cn-qingdao.aliyuncs.com/acs/agent:0.7-dfb6816
    使用 "docker push" 命令将该镜像推送至远程。
    
    $ docker push registry-vpc.cn-qingdao.aliyuncs.com/acs/agent:0.7-dfb6816
    

    6、测试推送发布

    ## 1、登录阿里云
    [root@Linux tomcat]# docker login --username=13479615108 registry.cn-qingdao.aliyuncs.com
    Password: 
    Error response from daemon: Get https://registry.cn-qingdao.aliyuncs.com/v2/: unauthorized: authentication required
    [root@Linux tomcat]# clear
    [root@Linux tomcat]# docker login --username=13479915208 registry.cn-qingdao.aliyuncs.com
    Password: 
    WARNING! Your password will be stored unencrypted in /root/.docker/config.json.
    Configure a credential helper to remove this warning. See
    https://docs.docker.com/engine/reference/commandline/login/#credentials-store
    
    Login Succeeded
    ## 2、设置 tag
    [root@Linux tomcat]# docker tag ecc82f059377 registry.cn-qingdao.aliyuncs.com/docker-guardwhy/java-test:v1.0
    
    ## 3、推送命令
    [root@Linux tomcat]# docker push registry.cn-qingdao.aliyuncs.com/docker-guardwhy/java-test:v1.0
    The push refers to repository [registry.cn-qingdao.aliyuncs.com/docker-guardwhy/java-test]
    c7510b7d4b11: Pushed 
    d6d45250595e: Pushed 
    3a1d1e2371ce: Pushed 
    70d71810a13c: Pushed 
    2653d992f4ef: Pushed 
    v1.0: digest: sha256:8baa27772f6fc09c79c5e9d986c397c243c49f601d287b9ee42781e931cae136 size: 1373
    [root@Linux tomcat]# 
    

    7、小结

  • 相关阅读:
    Ajax
    Guitar and Music Theory
    leetcode62 不同路径(Medium)
    leetcode49 字母异位词分组(Medium)
    leetcode3 无重复的最长子串(Medium)
    leetcode69 x的平方根(Easy)
    leetcode300 最长上升子序列(Medium)
    leetcode240 搜索二维矩阵II (Medium)
    leetcode34 在排序数组中查找元素的第一个和最后一个位置(Medium)
    leetcode31 下一个排列(Medium)
  • 原文地址:https://www.cnblogs.com/Guard9/p/14906580.html
Copyright © 2011-2022 走看看