欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

Spring Boot使用Docker分层打包的设置方法

程序员文章站 2022-03-13 07:56:00
spring boot项目使用docker容器, jar和war的分层打包。spring boot 现在支持分层打包技术了, 我们也来用一用, 加速docker打包, 构建的时候速度也会非常快.分层设...

spring boot项目使用docker容器, jar和war的分层打包。

spring boot 现在支持分层打包技术了, 我们也来用一用, 加速docker打包, 构建的时候速度也会非常快.

分层设置

首先pom里面要类似设置:

<plugin>
                    <groupid>org.springframework.boot</groupid>
                    <artifactid>spring-boot-maven-plugin</artifactid>
                    <version>${spring-boot.version}</version>
                    <configuration>
                        <!-- 启用分层打包支持 -->
                        <layers>
                            <enabled>true</enabled>
                        </layers>
                    </configuration>
                    <executions>
                        <execution>
                            <goals>
                                <goal>repackage</goal>
                            </goals>
                        </execution>
                    </executions>
                </plugin>

声明了 spring-boot-maven-plugin插件, 设置了layers配置, 开启分层支持.

打包完毕后, 我们检查jar包或者war包, 会发现多了一个 layers.idx文件, 里面包含了分层文件列表

- "dependencies":
  - "web-inf/lib-provided/"
  - "web-inf/lib/hikaricp-4.0.3.jar"
  - "web-inf/lib/aspectjweaver-1.9.5.jar"
  ...
  ...
- "spring-boot-loader":
  - "org/"
- "snapshot-dependencies":
  - "web-inf/lib/ms-fundmain-base-1.0-snapshot.jar"
  - "web-inf/lib/xpower-main-1.0.3-snapshot.jar"
  - "web-inf/lib/xpower-utils-1.0.3-snapshot.jar"
- "application":
  - "meta-inf/"
  - "web-inf/classes/"
  - "web-inf/jetty-web.xml"
  - "web-inf/layers.idx"
  - "pages/"
  - "static/"

此文件就是下面分层设置的依据.

如果是jar里面还有个classpath.idx文件, 里面列出了所有依赖的jar包.

打包的时候我们可以使用docker build 或者使用 docker-maven-plugin 插件来实现.

注意: spring-boot-maven-plugin 插件

本身就有docker打包功能, 不过下载打包速度太慢, 非常感人, 所有这里就不推荐了. --- 好处就是不用写dockerfile, 简单方便, 缺点就是不能定制docker文件.
配置类似如下:

<plugin>
    <groupid>org.springframework.boot</groupid>
    <artifactid>spring-boot-maven-plugin</artifactid>
    <configuration>
        <image>
            <!--配置镜像名称-->
            <name>127.0.0.1:5000/springcnscud/${project.name}:${project.version}</name>
            <!--镜像打包完成后自动推送到镜像仓库-->
            <publish>true</publish>
        </image>
        <docker>
            <!--docker远程管理地址-->
            <host>http://127.0.0.1:2375</host>
            <!-- 不使用tls访问-->
            <tlsverify>false</tlsverify>
            <!--  docker推送镜像仓库配置-->
            <publishregistry>
                <!--推送镜像仓库用户名-->
                <username>cnscud</username>
                <!--推送镜像仓库密码-->
                <password>123456</password>
                <!--推送镜像仓库地址-->
                <url>http://127.0.0.1:5000</url>
            </publishregistry>
        </docker>
    </configuration>
</plugin>

如果使用 docker-maven-plugin + 自定义dockerfile的方式:

pom配置:

    <plugin>
                    <groupid>io.fabric8</groupid>
                    <artifactid>docker-maven-plugin</artifactid>
                    <version>${docker.plugin.version}</version>
                    <configuration>
                        <!-- docker remote api-->
                        <!-- 本机则可以注释掉, 如果没有监听2375端口 -->
                        <dockerhost>${docker.host}</dockerhost>
                        <!-- docker 镜像私服-->
                        <registry>${docker.registry}</registry>

                        <images>
                            <image>
                                <name>${docker.registry}/${docker.namespace}/${project.name}:${project.version}</name>
                                <build>
                                    <dockerfiledir>${project.basedir}</dockerfiledir>
                                </build>
                            </image>
                        </images>
                    </configuration>
                </plugin>

我们来看看spring boot的jar方式下的dockerfile格式:

# 分层构建, 加速增量构建

from adoptopenjdk/openjdk8:centos-slim as builder

workdir application
arg jar_file=target/*.jar
copy ${jar_file} app.jar
run java -djarmode=layertools -jar app.jar extract && rm app.jar

from adoptopenjdk/openjdk8:centos-slim

label maintainer="cnscud@gmail.com"

env tz=asia/shanghai
run ln -snf /usr/share/zoneinfo/$tz /etc/localtime && echo $tz > /etc/timezone
env java_opts="-xms128m -xmx256m"

workdir application

copy --from=builder /application/dependencies/ ./
copy --from=builder /application/snapshot-dependencies/ ./
copy --from=builder /application/spring-boot-loader/ ./
copy --from=builder /application/application/ ./

expose 9001

entrypoint ["sh", "-c", "java $java_opts org.springframework.boot.loader.jarlauncher"]

里面的jdk请根据自己的情况修改, jar的情况下使用 jarlauncher.

如果是war怎么设置哪?

首先注意, 如果要独立运行, 可以使用嵌入式tomcat或jetty, pom里不要设置provider

 <dependency>
            <groupid>org.springframework.boot</groupid>
            <artifactid>spring-boot-starter-tomcat</artifactid>
        </dependency>

这样打包的时候就会包含嵌入式tomcat.

dockerfile设置如下:

# 分层构建, 加速增量构建

from adoptopenjdk/openjdk8:centos-slim as builder

workdir application
arg jar_file=target/*.war
copy ${jar_file} app.war
run java -djarmode=layertools -jar app.war extract && rm app.war

from adoptopenjdk/openjdk8:centos-slim
label maintainer="cnscud@gmail.com"

env tz=asia/shanghai
run ln -snf /usr/share/zoneinfo/$tz /etc/localtime && echo $tz > /etc/timezone
env java_opts="-xms128m -xmx256m"

workdir application

copy --from=builder /application/dependencies/ ./
copy --from=builder /application/snapshot-dependencies/ ./
copy --from=builder /application/spring-boot-loader/ ./
copy --from=builder /application/application/ ./

expose 8000

entrypoint ["sh", "-c", "java $java_opts org.springframework.boot.loader.warlauncher"]

注意文件名, 运行使用 warlauncher.

使用外部tomcat

未经实验, 构建分层可能比较麻烦...不过理论上也可以, 就是使用解压过的war包,而不是让tomcat自己解压

这里就不尝试了, 主要要点就是基础包换成tomcat, 运行的entrypoint换成tomcat, 中间把文件复制到容器里.

from tomcat:9.0

#将target下的xx.war拷贝到/usr/local/tomcat/webapps/下
add ./target/xx.war /usr/local/tomcat/webapps/

#端口
expose 8080

#设置启动命令
entrypoint ["/usr/local/tomcat/bin/catalina.sh","run"]

到此这篇关于spring boot使用docker分层打包的文章就介绍到这了,更多相关docker分层打包内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!