• Docker镜像打包示例


    一、war包(SpringMVC项目)镜像部署

    1、拉取tomcat镜像

    docker pull tomcat:8.5.30

    2、上传需要部署的war包(以hello.war为例)到自定义的工作目录下

    3、在上个步骤创建的工作目录下创建Dockerfile文件。将war包和Dockerfile文件放在同一目录下。Dockerfile文件内容如下:

    from tomcat:8.5.30
    
    ENV LANG C.UTF-8
    
    ENV TZ=Asia/Shanghai
    
    ENV JAVA_OPTS "-Djava.awt.headless=true"
    
    RUN touch /usr/local/tomcat/bin/setenv.sh && chmod +x /usr/local/tomcat/bin/setenv.sh && echo "CLASSPATH=/xx/hello" >/usr/local/tomcat/bin/setenv.sh
    
    RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
    
    RUN rm -rf /usr/local/tomcat/webapps/*
    
    ADD hello.war? /usr/local/tomcat/webapps/
    
    WORKDIR /usr/local/tomcat/bin/
    
    CMD ["catalina.sh", "run"]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    4、创建镜像(注:-t 表示为该镜像起名称,另外,构建命令后面有个英文实心点,表示当前目录。)

    docker build -t hello .

    5、通过docker images可以查看该镜像是否已经创建成功了

    docker images | grep hello

    6、运行自己的镜像,查看是否正常启动(注: -d:表示在后台运行该镜像,按ctrl+C不会终止该程序;-p:表示指定本机的访问端口对应容器的端口)

    docker run -d -p 30802:8080 hello

    7、docker镜像导出,tar镜像包可以拷贝到其他机器docker环境中加载

    docker save hello -o hello.tar

    8、docker镜像加载

    docker load -i hello.tar

    9、测试示例

    http://ip:30802/hello

    二、zip包(SpringBoot项目)镜像部署

    1、拉取tomcat镜像

    docker pull java:8

    2、上传需要部署的zip包(以hello.zip为例)到自定义的工作目录下。

    3、在上个步骤创建的工作目录下创建Dockerfile文件。将zip包解压,和Dockerfile文件放在同一目录下。Dockerfile文件内容如下:

    from java:8
    
    ENV LANG C.UTF-8
    
    ENV TZ=Asia/Shanghai
    
    ENV JAVA_OPTS=" -Dspring.config.location=/hello/application.properties"
    
    RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
    
    ADD hello.zip? .
    
    RUN unzip hello.zip
    
    RUN chmod +x /hello/bin/start.sh
    
    RUN chmod +x /hello /bin/stop.sh
    
    CMD cd /hello /bin/&&./start.sh
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    4、创建镜像(注:-t 表示为该镜像起名称,另外,构建命令后面有个英文实心点,表示当前目录。)

    docker build -t hello .

    5、通过docker images可以看到该镜像已经创建成功了

    docker images | grep hello

    6、运行自己的镜像(注: -d:表示在后台运行该镜像,按ctrl+C不会终止该程序;-p:表示指定本机的端口对应容器中的端口。-it表示以交互模式运行容器并分配伪终端。uap-service项目内置了一个tomcat容器,在其application.properties配置文件中server.port=8080。若设置server.port=xxx,则命令相应位置为30803:xxx)(打开伪终端,进去容器)

    docker run -p 30803:8080 hello

    7、docker镜像导出,tar镜像包可以拷贝到其他机器docker环境中加载

    docker save hello -o hello.tar

    8、docker镜像加载

    docker load -i hello.tar

    9、测试示例

    http://ip:30803/hello

    三、镜像部署常用操作

    查看所有容器

    docker ps -a

    停止容器运行

    docker stop {containerID}

    删除容器(-f强制删除,正在运行的容器也删除)

    docker rm -f {containerID}

    删除镜像(-f强制删除,否则需先停止容器运行才能删除镜像)

    docker rmi -f hello

    镜像打tag(可以用这种方法更新tag)

    docker tag hello hello:1.0.0

    查看指定镜像

    docker images |grep hello

    查看指定进程

    docker ps | grep hello

    将镜像push到镜像仓库

    docker push xx.xx.xx.xx/hello

    进入正在运行的容器执行指令(exec命令进入容器再退出后,容器不会停止;attach进入容器再退出后,容器停止)

    docker exec -it 0e6d50eb1469(container ID) /bin/bash

    docker attach 0e6d50eb1469(container ID)

    退出容器

    exit / ctrl + c

    根据容器的状态,删除exited状态的容器

    sudo docker rm $(sudo docker ps -qf status=exited)

    退出容器伪终端

    按顺序依次ctrl+p,ctrl+q(退出终端不关闭容器)

    exit或ctrl+d(退出终端并关闭容器)

    CMD

    支持三种格式

    CMD[“executable”,“param1”,“param2”]使用exec执行,推荐方式;

    CMDcommandparam1param2在/bin/sh中执行,提供给需要交互的应用;

    CMD[“param1”,“param2”]提供给ENTRYPOINT的默认参数;

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

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

    ENTRYPOINT

    两种格式:

    ENTRYPOINT[“executable”,“param1”,“param2”]

    ENTRYPOINTcommandparam1param2(shell中执行)。

    配置容器启动后执行的命令,并且不可被dockerrun提供的参数覆盖。每个Dockerfile中只能有一个ENTRYPOINT,当指定多个时,只有最后一个起效。

    在容器执行脚本时,注意。当前容器本身是主进程,start.sh的操作是守护进程,必须保证最后一个守护进程处于前台运行状态,否则容器会在执行脚本完成会自动关闭容器,容器停止运行后,所有的脚本里面的进程也随之终止。

    之所以出现这种现象,究其原因,一个docker容器同时只能管理一个进程,这个进程退出后,容器也就退出了。这并不意味着一个容器里只能同时运行一个进程(那样太浪费了),只是最后一个运行的进程不能退出。

    修改start.sh,保持java命令前台运行,即可避免容器在执行完脚本后exited的情况。start.sh修改如下:

    #! /bin/sh
    
    
    APPNAME=com.xx.xx.rest.Application
    
    java -Xms2048m -Xmx2048m -classpath $CLASSPATH $APPNAME >/dev/null 2>&1
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    start.sh总结总结:

    (1)容器中运行多个守护进程时,前面的进程要用后台方式运行(或添加 &),否则后面的服务无法启动。

    (2)容器中最后一个守护进程一定要用前台方式运行,否则start.sh退出,容器退出,所有的服务就白启动了。

  • 相关阅读:
    SIP系统组成格式
    C#语法基础
    202435读书笔记|《半小时漫画中国史》——读点经济学与历史,生活更美好,趣味烧脑土地制度、商鞅变法、华丽丽的丝绸之路这里都有
    mysql之SQL练习
    视频特效-使用ffmpeg滤镜
    计算机竞赛 : 题目:基于深度学习的水果识别 设计 开题 技术
    Docker 运行percona tokudb 引擎
    POCsuite与goland实现华为HG532路由器命令注入CVE-2017-17215 POC
    封装element-plus上传图片组件
    IOday6
  • 原文地址:https://blog.csdn.net/m0_54850825/article/details/126327689