SpringBoot 项目打包分开lib,配置和资源文件

原文地址:https://blog.csdn.net/u012811805/article/details/80878848

1 jar启动分离依赖lib和配置
  先前发布boot项目的时候,改动一点东西,就需要将整个项目重新打包部署,十分不便,故把依赖lib从项目分离出来,每次部署只需要发布代码即可。
1.1 半自动化步骤
1.1.1 更换maven的jar打包插件
  先前使用的是spring-boot-maven-plugin来打包,这个插件会将项目所有的依赖打入BOOT-INF/lib下,替换为maven-jar-plugin:

   <plugin>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-jar-plugin</artifactId>
      <version>3.1.1</version>
      <configuration>
         <archive>
            <manifest>
               <addClasspath>true</addClasspath>
               <classpathPrefix>lib/</classpathPrefix>
               <mainClass>org.orcrtech.pvpsddp.registry.center.PvpsddpRegistryCenterApplication</mainClass>
            </manifest>
         </archive>
      </configuration>
   </plugin>

  解释:
    a addClasspath表示需要加入到类构建路径
    b classpathPrefix指定生成的Manifest文件中Class-Path依赖lib前面都加上路径,构建出lib/xx.jar

1.1.2 拷贝依赖到jar外面的lib目录

  

<plugin>
      <groupId>org.apache.maven.plugins</groupId>
      <artifactId>maven-dependency-plugin</artifactId>
      <executions>
         <execution>
            <id>copy-lib</id>
            <phase>package</phase>
            <goals>
               <goal>copy-dependencies</goal>
            </goals>
            <configuration>
               <outputDirectory>target/lib</outputDirectory>
               <excludeTransitive>false</excludeTransitive>
               <stripVersion>false</stripVersion>
               <includeScope>runtime</includeScope>
            </configuration>
         </execution>
      </executions>
   </plugin>

  

1.1.3 在和jar包同级的目录下新建一个config目录,放入application.yml文件
  这里可能有小伙伴有疑问了,打包的jar里面不是应该有application.yml文件吗,这里为什么再放一份?
  这是因为boot读取配置有一个优先级,放在jar包外面config目录优先级最高,主要是便于从外部修改配置,而不是改jar包中的application.yml文件。优先级如下:
    当前目录的config目录下
    当前目录
    classpath的config目录下
    classpath的根目录

1.1.4 启动项目
  加入–debug可以让你可以看到比较详细的启动日志:
    java -jar xxx-1.0.0.jar --debug

1.2 全自动化步骤
  前面介绍的步骤中,需要手动的拷贝application.yml文件,并且jar包内外都存在配置,总感觉怪怪的(偷笑…)。这里引入一种自动化配置,将所有东西打成zip文件,直接发布到服务目录,解压后,即可启动。
1.2.1 指定打包插件
  如上。
1.2.2 拷贝依赖的插件。
  如上。
1.2.3 自动化步骤2
  排除resources下面的yml(因为我们需要把它放在jar外部,不能让jar打包插件将其打入jar包classpath下去)

<resources>
        <resource>
            <directory>src/main/resources</directory>
            <excludes>
                <exclude>**/application.yml</exclude>
            </excludes>
        </resource>
</resources>

  上面这种排除*.yml配置文件的办法,会在IDEA编译器启动的时候报错,下面的排除方法不会引起报错:

<plugin>
   <groupId>org.apache.maven.plugins</groupId>
   <artifactId>maven-jar-plugin</artifactId>
   <configuration>
      <archive>
         <manifest>
            <addClasspath>true</addClasspath>
            <classpathPrefix>lid/</classpathPrefix>
            <mainClass>org.orcrtech.pvpsddp.structure.management.PvpsddpStructureManagementApplication</mainClass>
         </manifest>
      </archive>
      <!-- 排除配置文件 -->
      <excludes >
         <exclude>*.yml</exclude>
      </excludes>
   </configuration>
</plugin>

1.2.4 使用maven-assembly-plugin自定义打包
  具体打包详情在assembly.xml配置中指定

<plugin>
    <artifactId>maven-assembly-plugin</artifactId>
    <configuration>
         <!-- 打包后的包名是否包含assembly的id名 -->
        <appendAssemblyId>false</appendAssemblyId>
          <!-- 指定最后tar或者zip包的名字 -->
          <finalName>gateway</finalName>
          <!-- tar或者zip包的输出目录 -->
          <!-- ../ 是指当前项目的根目录 ,例如:F:\pvpsddp\pvpsddp-gateway 的上一级-->
          <outputDirectory>F:\pvpsddp\tar</outputDirectory>
        <descriptors>
              <!-- 引用的assembly配置文件,可以用多个,即可以同时打包多个格式的包 -->
            <descriptor>src/main/resources/assembly.xml</descriptor>
        </descriptors>
    </configuration>
    <executions>
      <!-- phase加入package后,则在执行maven package时就可以调用maven-assembly-plugin插件定义的打包方式 -->
        <execution>
          <!--名字任意 -->
            <id>make-assembly</id>
           <!-- 绑定到package生命周期阶段上 -->
            <phase>package</phase>
            <goals>
               <!-- 只运行一次 -->
                <goal>single</goal>
            </goals>
        </execution>
    </executions>
</plugin>

  注:
    生成的tar.gz文件的名字为:maven-assembly-plugin插件中配置的 “finalName-assembly.xml配置的id”(若assembly中没有指定id,则只有前半部分。
    assembly.xml具体配置如下:
    将application.yml放在外部config目录下
    所有依赖打成zip压缩包(还可以打成其他类型包https://www.cnblogs.com/f-zhao/p/6929814.html)

<assembly xmlns="http://maven.apache.org/ASSEMBLY/2.0.0"
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
          xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/2.0.0 http://maven.apache.org/xsd/assembly-2.0.0.xsd">
<id>package</id>
<formats>
    <format>zip</format>
</formats>
<includeBaseDirectory>true</includeBaseDirectory>
<fileSets>
    <fileSet>
        <directory>${basedir}/src/main/resources</directory>
        <includes>
            <include>*.yml</include>
        </includes>
        <filtered>true</filtered>
        <outputDirectory>${file.separator}config</outputDirectory>
    </fileSet>

    <fileSet>
        <!-- 需要打包的路径 -->
        <directory>src/main/resources/runScript</directory>
        <!-- 打包后输出的路径,自定义 -->
        <outputDirectory>${file.separator}bin</outputDirectory>
    </fileSet>
    <fileSet>
        <directory>${project.build.directory}/lib</directory>
        <outputDirectory>${file.separator}lib</outputDirectory>
        <!-- 打包需要包含的文件 -->
        <includes>
            <include>*.jar</include>
        </includes>
    </fileSet>
    <fileSet>
        <directory>${project.build.directory}</directory>
        <outputDirectory>${file.separator}</outputDirectory>
        <includes>
            <include>*.jar</include>
        </includes>
    </fileSet>
</fileSets>
</assembly>

原文地址:https://www.cnblogs.com/lishan1/p/10317488.html

时间: 2024-11-03 21:07:05

SpringBoot 项目打包分开lib,配置和资源文件的相关文章

springboot 项目打包部署后设置上传文件访问的绝对路径

1.设置绝对路径 application.properties的配置 #静态资源对外暴露的访问路径 file.staticAccessPath=/upload/** #文件上传目录(注意Linux和Windows上的目录结构不同) #file.uploadFolder=/home/upload/ file.uploadFolder=d://upload/ 配置上传文件的目录,也可以在这里设置上传文件的大小 @Configuration public class UploadFileConfig

SpringBoot 项目打包后获取不到resource下资源的解决

SpringBoot 项目打包后获取不到resource下资源的解决 在项目中有几个文件需要下载,然后不想暴露真实路径,又没有CDN,便决定使用接口的方式来获取文件.最初的时候使用了传统的方法来获取文件路径,发现不行.查找资料后发现是SpringBoot框架导致的,得用另外的方法: //听说在linux系统中会失效. //不用听说了,就是会挂,血的教训 String path = ResourceUtils.getURL("classpath:").getPath(); //此方法返回

解决Eclipse建立Maven项目后无src/main/java资源文件夹的办法

建立好一个Maven项目后,如果Java Resources资源文件下没有src/main/java文件夹,并且在手动创建这个文件时提示"已存在文件".这说明,在这个项目配置中已经有了src/main/java这个文件夹. 解决方法: 在项目上右键选择properties,然后点击java build path,在Librarys下,编辑JRE system Library,配置JDK路径.

Eclipse中创建新的SpringBoot项目(打包并且部署到tomcat)

Spring-boot因为其对jar包的高度集成以及简化服务配置,快速部署等的优点,逐渐成为Java开发人员的热衷的框架.下面演示一下怎么在Eclipse中新建Spring-boot项目以及打包部署. 在Eclipse中创建Spring-boot有两种方式 方式一 进入Spring-boot的在线配置网站http://start.spring.io/:定制自己的项目服务组件,下载到本地并使用Eclipse导入项目 服务组件: Web:web项目组件,包含spring mvc,tomcat,log

maven 打包时动态替换properties资源文件中的配置值

pom build节点下面添加resource配置: [html] view plain copy <resources> <resource> <directory>src/main/resources/</directory> <filtering>true</filtering> <includes> <include>**/*.properties</include> </includ

SpringBoot项目打包出错

首先确定项目都能跑通的情况下,在跟项目打包时报错 Failed to execute goal org.apache.maven.plugins:maven-surefire-plugin:2.21.0:test (default-test) on project spring_boot: There are test failures. 大概意思是测试文件打包失败. 既然失败,那就忽视测试文件. 在测试类中添加给注解@Ignore @Ignore 在类上添加就是忽视这个类, 在方法上添加就是忽

Android Studio下通过Gradle配置实现资源文件的模块化

当开发一个app模块个数很多的时候,资源文件就会特别多,布局也会多起来,这时所有的layout都放在同一个目录下,就会显得臃肿,而且不好找相应的布局. 最近看到相关资料,发现在Android Studio下可以配置多个res目录,用来分割不同的模块. 如下图所示,可以在一个新的模块的res目录下 创建各种资源目录: 当然还可以在res-qa目录下创建 drawable,values等目录 这些资源文件可以和原来的一样直接R文件引用. 上面仅仅是效果,还需要在 build.gradle中进行配置

maven项目打包的时候,*Mapper.xml 文件会打不不进去解决办法

打包的时候,不同版本的 Eclipse 还有IDEA 会有打包打不进去Mapper.xml 文件,这个时候要加如下代码, 在<build> 标签内加入即可 <resources> <resource> <directory>src/main/java</directory> <includes> <include>**/*.properties</include> <include>**/*.xml

Java SpringBoot 项目打包

前提条件 1.已安装配置好maven Maven打包命令介绍 mvn clean package  依次执行了clean.resources.compile.testResources.testCompile.test.jar(打包)等7个阶段: mvn clean install     依次执行了clean.resources.compile.testResources.testCompile.test.jar(打包).install等8个阶段: mvn clean deploy    依次