- 一、前言
- 二、正文
- 1.整个项目的目录结构
- 2.系统环境变量配置
- 3.pom文件配置——本文重点,其它部分甚至不用看
- 4. 打包
- 5.测试,测试依赖于前两篇所构建的测试项目,当然这不重要
- 三、总结
昨天和项目组内一位经验丰富的老师傅探讨,围绕着SpringBoot打包后动不动就一百多兆,在现场远程维护部署时非常不方便的问题,进行了一番请教。问题的根本是:有时候仅仅改动了一点点东西,却要发给现场替换包含所有依赖的jar包,这非常的笨重不方便。
于是又学到了新知识。抽空浏览了网上的资料,结合工作中的实际使用场景,整理了本文的内容,方便后期随时取用。
二、正文之前一直使用SpringBoot初始化建立项目默认的spring-boot-maven-plugin插件,进行项目打包,这个插件会将项目所有的依赖打入BOOT-INF/lib下,这就导致了jar包的体积非常臃肿,尤其涉及到几十个子项目时,整个项目的体积可想而知。但是,各项目之间有非常的公共依赖,因此,分离打包还是比较有意义的。
本文还是在上两篇的项目上进行测试,毕竟只改了pom文件中的build标签下的插件内容
如果有兴趣可翻阅:SpringBoot整合新版Mybatis-Plus代码生成器、SpringBoot整合Knife4j替代Swagger。
pom中几乎所有的配置项都有比较详细的注释,表明每个属性是做什么,以及如何配置,请根据项目实际进行配置。
- properties标签中定义依赖的输出目录、jar包的输出目录、resources中配置文件的输出目录。
lib/ bin/ config/
- build标签:plugins标签中一共包含三个插件:maven-jar-plugin、maven-dependency-plugin和maven-resources-plugin。
啰嗦一句,在下方配置中会看到有…/这种相对路径的配置,其实非常简单,只要把握住一点,一切从最终的jar包出发,考虑如何让它能够找到它所依赖的lib和配置文件即可。
4. 打包org.apache.maven.plugins maven-jar-plugin ${env.LEARN_HOME}/${output.jar.file.path} *.properties *.yml *.xml *.txt true false true ../${output.dependence.file.path} com.ieslab.knife4j.demo.DemoApplication ../${output.resource.file.path} org.apache.maven.plugins maven-dependency-plugin copy-dependencies package copy-dependencies ${env.LEARN_HOME}/${output.dependence.file.path} false false org.apache.maven.plugins maven-resources-plugin copy-resources package copy-resources src/main/resources *.properties *.yml *.xml *.txt ${env.LEARN_HOME}/${output.resource.file.path}
首先,把右上角的闪电图标点上,可以在打包时“跳过测试模式”。然后分别双击执行clean和package命令,进行清理和打包。
打包成功:
打包完成后,我们去输出目录看一下:
进入bin目录下:在地址栏输入cmd回车
启动项目:java -jar demo-1.0.0.jar
启动成功:
浏览器输入knife4j地址验证一下:
本文关于SpringBoot分离打包的内容就这么多,有兴趣可以试一下。
当然还有很多不足需要继续探索的地方,比如,将所有的配置文件都输出到config目录下,项目很多怎么办?是不是应该考虑config目录下,每一个子项目一个独立目录?还有整个项目的公共配置如何处理?不可能每个项目都维护一份公共配置信息,万一修改需要修改很多处,那需要怎么解决?
下次见。



