分离后 :
java -jar -Dloader.path=lib xxx.jar
#逗号分割的 多个路径 -Dloader.path=.,lib 当前目录及lib目录
pom 常规配置
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>${java.version}</source>
<target>${java.version}</target>
</configuration>
</plugin>
</plugins>
</build>
方式一:
mvn clean dependency:copy-dependencies -DoutputDirectory=target/lib package -e
关键部分:dependency:copy-dependencies -DoutputDirectory=target/lib
将项目依赖项从存储库复制到定义位置的目标。
pom 完成配置
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<mainClass>com.htrip.app.CtripDataApplation</mainClass>
<layout>ZIP</layout>
<includes>
<include>
<groupId>com.htrip</groupId>
<artifactId>htrip-ctrip-data</artifactId>
</include>
</includes>
</configuration>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>${java.version}</source>
<target>${java.version}</target>
</configuration>
</plugin>
<!--拷贝依赖到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>compile</includeScope>-->
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
关键配置解读
<layout>ZIP</layout>
layout属性的值可以如下:
JAR,即通常的可执行jar
Main-Class : org.springframework.boot.loader.JarLauncher
WAR,即通常的可执行war,需要的servlet容器依赖位于WEB-INF/lib-provided
Main-Class : org.springframework.boot.loader.warLauncher
ZIP,即DIR,类似于JAR
Main-Class : org.springframework.boot.loader.PropertiesLauncher
MODULE,将所有的依赖库打包(scope为provided的除外),但是不打包Spring Boot的任何Launcher。
NONE,将所有的依赖库打包,但是不打包Spring Boot的任何Launcher。
PropertiesLauncher有一些特殊的性质,它们可以通过外部属性来启用(系统属性,环境变量,manifest实体或application.properties)。
Key作用loader.path逗号分割的classpath,比如lib:${HOME}/app/libloader.home其他属性文件的位置,比如[/opt/app](file:///opt/app)(默认为${user.dir})loader.argsmain方法的默认参数(以空格分割)loader.main要启动的main类名称,比如com.app.Applicationloader.config.name属性文件名,比如loader(默认为application)loader.config.location属性文件路径,比如classpath:loader.properties(默认为application.properties)loader.system布尔标识,表明所有的属性都应该添加到系统属性中(默认为false)Manifest实体keys通过大写单词首字母及将分隔符从"."改为"-"(比如Loader-Path)来进行格式化。loader.main是个特例,它是通过查找manifest的Start-Class,这样也兼容JarLauncher。
环境变量可以大写字母并且用下划线代替句号。
loader.home是其他属性文件(覆盖默认)的目录位置,只要没有指定loader.config.location。
loader.path可以包含目录(递归地扫描jar和zip文件),存档路径或通配符模式(针对默认的JVM行为)。
占位符在使用前会被系统和环境变量加上属性文件本身的值替换掉
其中${project.build.directory}是maven变量,表示target目录。如果不写的话,将在根目录下创建lib目录。
excludeTransitive,表示是否不包含间接依赖的包;
stripVersion表示复制的jar文件去掉版本信息。
参考链接:
https://blog.csdn.net/beijihukk/article/details/113855156
未验证 分离配置文件
https://blog.csdn.net/u012811805/article/details/80878848