纯净、安全、绿色的下载网站

首页|软件分类|下载排行|最新软件|IT学院

当前位置:首页IT学院IT技术

SpringBoot多模块服务调用 Spring Boot多模块化后,服务间调用的坑及解决

皮卡卡西   2021-06-09 我要评论
想了解Spring Boot多模块化后,服务间调用的坑及解决的相关内容吗皮卡卡西在本文为您仔细讲解SpringBoot多模块服务调用的相关知识和一些Code实例欢迎阅读和指正我们先划重点:Spring,Boot多模块,服务调用下面大家一起来学习吧

问题背景:

product 服务作为服务端提供了一个 对外通信Fegin接口 ProductClient放在了com.imooc.product.client jar包下

order 服务作为客户端直接引用上面的jar使用 ProductClient 启动主类后报下图错误:

解决办法:

多模块化时,应该在order主类上添加下面圈出来的注解这样启动后就能扫描这个包

Maven多模块项目+SpringBoot编译失败:程序包xxx不存在

项目结构如下:

parent(父类工程)

|

| - - - - - common(通用工具类子工程)

|

| - - - - - projectA(springboot子工程依赖common工程)

|

pom.xml

问题描述:

通过parent父工程进行Maven installparent父工程和common子工程打包成功projectA子工程打包失败并报错

[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.1:compile (default-compile) on project projectA: Compilation failure

[ERROR] /xxxx.java:[14,36] 程序包com.xxx.xxx.utils不存在

注意:就算projectA能打包成功运行后调用也会报common下的类找不到异常为同一问题

关键错误信息截图:

解决方案:

在common子工程下的pom.xml添加以下配置

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
				<configuration>
					<classifier>exec</classifier>
				</configuration>
			</plugin>
		</plugins>
	</build>

原因分析:

common也是SpringBoot工程SpringBoot工程打包编译时会生成两种jar包一种是普通的jar另一种是可执行jar

默认情况下这两种jar的名称相同在不做配置的情况下普通的jar先生成可执行jar后生成造成可执行jar会覆盖普通的jar

而projectA工程无法依赖common工程的可执行jar所以编译失败:程序包xxx不存在

添加配置后截图如下其中common-1.0-SNAPSHOT-exec.jar为可执行jarcommon-1.0-SNAPSHOT.jar为普通jar包

以上为个人经验希望能给大家一个参考也希望大家多多支持


相关文章

猜您喜欢

网友评论

Copyright 2020 www.fresh-weather.com 【世纪下载站】 版权所有 软件发布

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 点此查看联系方式