专栏名称: 架构师
架构师云集,三高架构(高可用、高性能、高稳定)、大数据、机器学习、Java架构、系统架构、大规模分布式架构、人工智能等的架构讨论交流,以及结合互联网技术的架构调整,大规模架构实战分享。欢迎有想法、乐于分享的架构师交流学习。
目录
相关文章推荐
51好读  ›  专栏  ›  架构师

SpringBoot 多种生产打包方式详解

架构师  · 公众号  ·  · 2025-01-16 22:26

正文

架构师(JiaGouX)
我们都是架构师!
架构未来,你来不来?



生产上发布 Spring Boot 项目时,流程颇为繁琐且低效。但凡代码有一丁点改动,就得把整个项目重新打包部署,耗时费力不说,生成的 JAR 包还特别臃肿,体积庞大。每次更新项目,光是上传这大文件就得花费不少时间,严重影响工作节奏。

为解决这一痛点,我打算把依赖库以及配置文件(lib 文件夹下的那些 jar 包,还有config下的applacation.yml等文件)从项目主体里剥离出来,后续部署时,只需发布核心代码就行,这样既能加快部署速度,又能减轻文件传输负担,让项目更新变得轻松便捷

方法一 插件spring-boot-maven-plugin

1. 项目应用的配置文件排除 统一打包到config目录下

利用springboot中resource插件来排除配置,并统一打包到config目录下

<resources>
  <resource>
      <directory>src/main/resourcesdirectory>
       
       <filtering>truefiltering>
       
      <targetPath>${project.build.directory}/configtargetPath>
      <includes>
      
         <include>**/*.propertiesinclude>
         <include>**/*.ymlinclude>
         <include>**/*.xmlinclude>
     <include>mapper/*.xmlinclude>
      
   includes>
  resource>
resources>
2. 把我们写代码打包可执行jar,并排除依赖jar包
<plugin>
  <groupId>org.springframework.bootgroupId>
  <artifactId>spring-boot-maven-pluginartifactId>
  <configuration>
   
    
     <jvmArguments>-Dfile.encoding=UTF-8jvmArguments>
     <layout>ZIPlayout>
     
     <includes>
     
        <include>
             <groupId>no-exists-jargroupId>
            <artifactId>non-exists-jarartifactId>
         include>
      includes>
  configuration>
  <executions>
    <execution>
         <goals>
         
           <goal>repackagegoal>
       goals>
    execution>
  executions>
plugin>
3. 配置依赖的jar包 统一打包lib目录

<plugin>
   <groupId>org.apache.maven.pluginsgroupId>
   <artifactId>maven-dependency-pluginartifactId>
   <executions>
   <execution>
      <id>copy-dependenciesid>
      <phase>packagephase>
      <goals>
         <goal>copy-dependenciesgoal>
      goals>
     <configuration>
          <outputDirectory>${project.build.directory}/liboutputDirectory>
          <excludeTransitive>falseexcludeTransitive>
          <stripVersion>falsestripVersion>
          <includeScope>runtimeincludeScope>
      configuration>
    execution>
  executions>
plugin>

打包后目录结构,如下图所示

执行命令 java -jar -Dloader.path=./lib -jar xxx.jar

注意 springboot启动时候会优先读取config目录下配置文件 所以这里不用指定 -Dspring.config.location=XX.yml 文件

注意 例如日志文件配置以及mybits等配置文件 可以配成绝对路径 如下所示:

方法二 使用maven-jar-plugin插件实现

1. 使用插件maven-resources-plugin处理配置文件打包到config目录
<plugin>
    <groupId>org.apache.maven.pluginsgroupId>
    <artifactId>maven-resources-pluginartifactId>
    <configuration>
       <encoding>UTF-8encoding>
    configuration>
   <executions>
      <execution>
          <id>copy-dependenciesid>
          <phase>packagephase>
          <goals>
             <goal>copy-resourcesgoal>
          goals>
  <configuration>

      <outputDirectory>${project.build.directory}/twin-web/configoutputDirectory>
      <resources>
      <resource>
      <directory>src/main/resourcesdirectory>
      resource>
      resources>
     configuration>
  execution>
executions>
plugin>
2. 使用maven-jar-plugin 打包可执行jar 并排除依赖
<plugin>
   <groupId>org.apache.maven.pluginsgroupId>
   <artifactId>maven-jar-pluginartifactId>
   <configuration>
      <outputDirectory>
          
          ${project.build.directory}/twin-web/
       outputDirectory>
      <archive>
        <addMavenDescriptor>falseaddMavenDescriptor>
       <manifest>
             <addClasspath>trueaddClasspath>
         
           <classpathPrefix>./libs/classpathPrefix>
         
            <mainClass>com.keqing.twinweb.TwinWebApplicationmainClass>
        manifest>
        <manifestEntries>
          
          <Class-Path>./config/Class-Path>
      manifestEntries>
archive>

     <excludes>
         <exclude>*.ymlexclude>
         <exclude>mapper/**exclude>
         <exclude>*.xmlexclude>
     excludes>
  configuration>
plugin>
3. 使用maven-dependency-plugin 打包libs目录下
<plugin>
   <groupId>org.apache.maven.pluginsgroupId>
   <artifactId>maven-dependency-pluginartifactId>
   <executions>
   <execution>
      <id>copy-dependenciesid>
      <phase>packagephase>
      <goals>
         <goal>copy-dependenciesgoal>
      goals>
     <configuration>
          <outputDirectory>${project.build.directory}/twin-web/libsoutputDirectory>
          <excludeTransitive>falseexcludeTransitive>
          <stripVersion>falsestripVersion>
          <includeScope>runtimeincludeScope>
      configuration>
    execution>
  executions>
plugin>

使用package打包后的目录

查看自己打包后jar目录,注意这种打包方式弊端,按照一定约定格式规范固定了,一旦依赖jar包(包括配置文件目录等)发生变化就必须重新打包

启动程序 java -jar xxx.jar

方式三 使用maven-assembly-plugin打包

maven-assembly-plugin 是 Maven 中的一个插件,它允许用户将项目的输出以及依赖、模块、站点文档和其他文件打包成一个可发布的格式,例如 zip、tar.gz、jar 等。以下是使用 maven-assembly-plugin 的一些优势:

  • 自定义打包格式: maven-assembly-plugin 允许你通过定义描述符文件(descriptor)来完全自定义打包的内容和格式。你可以选择包含或排除特定的文件和目录。
  • 一键打包: 通过一个简单的 Maven 命令,你可以创建一个包含所有必需依赖的单一归档文件,这使得分发和部署变得非常简单。
  • 多环境支持: 可以为不同的环境(开发、测试、生产)创建不同的打包配置,使得环境迁移更加容易。
  • 依赖管理: 插件会自动处理项目依赖,将它们打包到最终的归档文件中,无需手动管理。
  • 模块化项目支持: 对于多模块项目,maven-assembly-plugin 可以将所有模块的输出合并到一个归档文件中。
  • 预配置的描述符: 插件提供了一些预定义的描述符,如 bin、jar-with-dependencies 等,可以直接使用,无需自定义。
  • 灵活性: 你可以通过修改描述符文件来调整打包行为,以适应不同的需求。
  • 集成性: maven-assembly-plugin 与 Maven 生态系统紧密集成,可以与其他 Maven 插件协同工作。
  • 文档和社区支持: 由于 maven-assembly-plugin 是 Maven 的一部分,因此有广泛的文档和社区支持。
1. 项目应用的配置文件排除
<resources>
  <resource>
         <directory>src/main/resourcesdirectory>
             
          <filtering>truefiltering>
         <includes>
             
            <include>**/*.propertiesinclude>
            <include>**/*.ymlinclude>
            <include>**/*.xmlinclude>
           <include>mapper/*.xmlinclude>
        
        includes>
   resource>
resources>
2. 配置spring-boot-maven-plugin

<plugin>
   <groupId>org.springframework.bootgroupId>
   <artifactId>spring-boot-maven-pluginartifactId






请到「今天看啥」查看全文