参考自:/SnailMann/article/details/81710461
之前我在练习一个springcloud微服务的项目,项目很简单,一个父类,一个注册中心,一个提供者,一个消费者。但是再项目编写完成后,项目打包总是失败。总是提示java实体类出问题。纠结了很久,最后解决了,这里好好做个总结。
这是一个什么问题呢?我来阐述一下,问题大致是这么一个情况:
我有一个SpringCloud项目,每个微服务都是一个SpringBoot工程,其中有一个payment项目依赖了一个公共的模块common-util项目。payment项目和common项目都同属一个父工程的子module。
- 此时我想要把整合SpringCloud项目部署到服务器上,这时候我就需要打jar包,将jar放到服务器上,通过java -jar *.jar 命令来启动SpringBoot项目
- 首先我肯定输入mvn clean install -DskipTests=true将common模块进行打包到本地仓库中
- 然后我再对payment项目进行打包mvn clean package -DskipTests=true
- 然后mvn命令error (找不到符号),既payment找不到common里的类,所以报错,无法打包
我分析的理由:
- 我一开始是检查是否父项目的pom漏了module common项目,发现不是,payment和common都是同属一个父项目的子module,而且子项目的<parent>也都一个同一个父项目
- 然后我又检查是否payment依赖的common的路径或版本号出了问题,发现也正确
- 然后我就检查是否.m2的仓库中,包没有打上,或者包不完整。检查后发现也没有
- 然后我就怀疑是否的依赖配置问题,但是网上查springboot多模块项目打包不成功的问题,也没有收获
最后的解决方案:
该方案是我在某群求助后,一大佬解决的,真的是非常感谢,帮我解决了困扰我一个下午的问题。
我的问题就是在common项目的pom导入了spring-boot-maven-plugin
插件,导致打的common jar包与平时的jar包不同。当该jar包被其他模块依赖,就会出现该jar无法被其他模块访问到。
<build>
<plugins>
<plugin>
<groupId></groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
所以如果你的项目Module仅仅是作为jar包依赖使用的,而不是一个SpringBoot启动项工程就千万不要把spring-boot-maven-plugin
插件配置到该项目的pom中。导入了该插件所打的jar包和没有该插件时所打的jar包是不同的。谨记
总结
在分布式即微服务项目中,在需要启动的项目的pom文件中添加上面的依赖,在实体类,工具类,等类似不需要启动,只需要继承,依赖的模块的服务中不需要上面的依赖。在父工程中也不需要加上上面的依赖。只要他们都直接或者间接的继承了父工程,父工程打包都会将其他依赖的服务打包。