maven 打包分离lib

分离后 :

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

Spring Boot的Maven插件Spring Boot Maven plugin详解

PropertiesLauncher特性

JarLauncher解读

maven 常见问题

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如果你想要在 Maven 项目中包含 Tomcat lib 中的 jar 包,你可以使用 maven-dependency-plugin 插件。 你需要在你的 pom.xml 文件中添加如下配置: ``` <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-dependency-plugin</artifactId> <version>3.1.2</version> <executions> <execution> <id>copy-dependencies</id> <phase>package</phase> <goals> <goal>copy-dependencies</goal> </goals> <configuration> <!-- specify the Tomcat lib directory --> <outputDirectory>${project.build.directory}/tomcat/lib</outputDirectory> <overWriteReleases>false</overWriteReleases> <overWriteSnapshots>false</overWriteSnapshots> <overWriteIfNewer>true</overWriteIfNewer> <!-- specify the jar files you want to include --> <includeArtifactIds>artifact1,artifact2</includeArtifactIds> </configuration> </execution> </executions> </plugin> </plugins> </build> ``` 在这里,你需要指定输出目录为 Tomcat lib 目录,并列出你想要包含的 jar 包的 artifactId。 然后,你可以使用以下命令来执行打包操作: ``` mvn package ``` 这样就可以在 Tomcat lib 目录中找到你打包的 jar 包了。 ### 回答2: 使用Maven打包Tomcat lib目录中的jar文件可以按照以下步骤进行: 1. 在项目的pom.xml文件中,添加Tomcat lib目录作为依赖: ``` <dependencies> <dependency> <groupId>org.apache.tomcat</groupId> <artifactId>tomcat-catalina</artifactId> <version>版本号</version> <scope>provided</scope> </dependency> <!-- 添加其他所需的依赖 --> </dependencies> ``` 2. 在Maven构建中,将Tomcat lib中的jar文件复制到项目的lib目录下。 在pom.xml文件中,添加以下插件配置将Tomcat lib中的jar文件复制到lib目录: ``` <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-dependency-plugin</artifactId> <version>版本号</version> <executions> <execution> <id>copy-dependencies</id> <phase>prepare-package</phase> <goals> <goal>copy-dependencies</goal> </goals> <configuration> <outputDirectory>${project.build.directory}/lib</outputDirectory> <includeScope>runtime</includeScope> </configuration> </execution> </executions> </plugin> </plugins> </build> ``` 3. 运行Maven打包命令。在命令行中进入项目根目录,执行以下命令: ``` mvn package ``` 执行完毕后,Maven将在target目录下生成构建好的war包文件。war包中将包含lib文件夹,其中包含了Tomcat lib目录中的jar文件及其他项目所需的依赖jar。 ### 回答3: 要将Tomcat lib目录中的JAR文件打包Maven项目中,可以按照以下步骤进行操作。 第一步,打开Maven项目的pom.xml文件,在<dependencies>标签中添加如下代码: ```xml <dependency> <groupId>com.example</groupId> <artifactId>jar1</artifactId> <version>1.0</version> <scope>system</scope> <systemPath>${basedir}/lib/jar1.jar</systemPath> </dependency> ``` 其中,`groupId`和`artifactId`需要根据实际情况进行修改。`version`可根据需要自行设置。`scope`设置为`system`表示引入的是系统路径中的JAR文件。`systemPath`指定了JAR文件的路径,该路径为相对于项目根目录的路径。 第二步,创建`lib`文件夹,并将需要打包的JAR文件复制到该文件夹中。 第三步,运行Maven打包命令,例如`mvn package`。Maven会将项目及其依赖打包成一个可执行的JAR文件,并将lib目录下的JAR文件一同打包进去。 完成上述步骤后,Maven项目将包含Tomcat lib目录下指定的JAR文件,并可以在项目中引用它们。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值