就是把lib包和source源码分开打包。优势就是,面对频繁更新的应用场景时,可以只更新源码包(当然,前提是你的依赖没有增减)。尤其是使用jenkins更新项目时,会省去很多时间吧?
不同项目的 lib之间不能合用,最好还是单独各干各的。也就是说两个项目的lib包虽然高度重合,但是这两个项目最好还是不要引用同一个
pom打包配置如下:
<build><finalName>lll_collector</finalName> <plugins><!--用于打成jar包--><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><configuration><mainClass>com.lll.cloud.Application</mainClass><jvmArguments>-Dfile.encoding=UTF8</jvmArguments><layout>ZIP</layout><includes><!--????--><include><groupId>nothing</groupId><artifactId>nothing</artifactId></include></includes></configuration><executions><execution><id>repackage</id><goals><goal>repackage</goal></goals></execution></executions></plugin><!--用于将依赖包导出--><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-dependency-plugin</artifactId><version>3.1.1</version><executions><execution><id>copy-dependencies</id><phase>package</phase><goals><goal>copy-dependencies</goal></goals><configuration><!-- 依赖包输出目录,将来不打进jar包里,而是到同级下(target)的libc文件夹中 --><outputDirectory>${project.build.directory}/libc</outputDirectory><excludeTransitive>false</excludeTransitive><stripVersion>false</stripVersion><includeScope>runtime</includeScope></configuration></execution></executions></plugin></plugins></build>
对比正常的打包,主要是这两个地方
启动命令
nohup java -jar -Dloader.path="libc" lll_server.jar &
- 注意,格式是
java -jar 【op】file.jar
,顺序不要弄混了,op在前
ERROR:本地jar包无法被引入
通过本地引入的jar包没有libs包中,
导致程序启动缺失包
目前解决方案:手动把这两个包迁移libc下
ERROR:tomcat依赖异常
tomcat的scope设置问题,注释掉scope=provided