2、Spring Boot 3.x 集成 Feign
一、前言
本篇主要是围绕着两个点,1、集成 Feign,2、分离feign接口层,独立服务;
还有一点就是上篇文章的服务 iot-channel、system-server 服务名称调整成为了 chain-iot-channel、chain-system
二、搭建 chain-common 服务
pom.xml
<properties>
<!-- lombok -->
<lombok.version>1.18.26</lombok.version>
</properties>
<!-- Dependencies -->
<dependencies>
<!-- Lombok Dependency -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombok.version}</version>
</dependency>
</dependencies>
chain-common 项目暂时只是空项目
二、搭建 chain-starter/chain-feign-starter 服务
chain-starter
chain-starter 服务只是一个 pom 项目,主要作用是来包含一些启动服务,例如 chain-feign-starter 之类
chain-feign-starter
搭建这个服务的主要是目的是,后续会有很多服务会引用到 Feign 框架,如果在每个服务独立引用 Feign,在后续的升级版本或需要增加 Feign 的配置就会很麻烦,所以现在统一管理起来
<dependencies>
<!-- feign 客户端 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
</dependencies>
三、chain-system、chain-iot-channel 集成 Feign
pom.xml 增加 Feign 引用
<dependency>
<groupId>com.chain</groupId>
<artifactId>chain-feign-starter</artifactId>
<version>${chain.version}</version>
</dependency>
四、服务配置 Feign
1、启动服务增加注解
在 chain-system、chain-iot-channel 启动服务都增加 @EnableFeignClients 注解,开发Feign 客户端
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class IotChannelServeApp {
public static void main(String[] args) {
SpringApplication.run(IotChannelServeApp.class, args);
}
}
@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class SystemServerApp {
public static void main(String[] args) {
SpringApplication.run(SystemServerApp.class);
}
}
2、chain-iot-channel 服务增加被调用接口
IotChannelInterface.java
@RestController
@RequestMapping(path = "/iot/channel/open/api")
public class IotChannelInterface {
@Override
@GetMapping(path = "/testIotChannelFeign")
public String testIotChannelFeign() {
return "test iot channel feign open api";
}
}
3、chain-system 服务增加调用接口
SystemForIotChannelInterfaceClient.java
@FeignClient(name = "chain-iot-channel", url = "http://localhost:10020", path = "/iot/channel/open/api")
public interface SystemForIotChannelInterfaceClient {
@GetMapping(path = "/testIotChannelFeign")
String testIotChannelFeign();
}
在这里需要注意一点的是,如果在 IotChannelInterface.java 中配置了@RequestMapping(path = "/iot/channel/open/api"),那么在 SystemForIotChannelInterfaceClient.java 中就需要增加 path = "/iot/channel/open/api" 配置
还有另一点就是如果单独使用 Feign,没有集成 Ribbon,那么就需要在 @FeignClient 注解中增加 url 配置项,因为没有 Ribbon 框架是无法实现负载均衡,那么 name 参数的配置,不会直接调用到服务的,只能增加 url 配置
五、独立 Feign 调用接口
1、增加 chain-open-api/chain-iot-channel-api 服务
chain-open-api
chain-open-api 和 chain-starter 服务一样,只是一个 pom 项目,主要作用是来包含项目中每个服务对应的 open api 项目
chain-iot-channel-api
pom.xml
<dependencies>
<!-- 自定义 Feign -->
<dependency>
<groupId>com.chain</groupId>
<artifactId>chain-feign-starter</artifactId>
<version>${chain.version}</version>
</dependency>
</dependencies>
IotChannelInterfaceApi.java
public interface IotChannelInterfaceApi {
/**
* 测试 iot channel 服务是否可用
*
* @return String
*/
@GetMapping(path = "/testIotChannelFeign")
String testIotChannelFeign();
}
2、增加对 chain-iot-channel-api 的引用
chain-iot-channel\chain-system
pom.xml
<dependency>
<groupId>com.chain</groupId>
<artifactId>chain-iot-channel-api</artifactId>
<version>${chain.version}</version>
</dependency>
3、改造IotChannelInterface.java、SystemForIotChannelInterfaceClient.java
IotChannelInterface.java、
@RestController
@RequestMapping(path = "/iot/channel/open/api")
public class IotChannelInterface implements IotChannelInterfaceApi {
@Override
public String testIotChannelFeign() {
return "test iot channel feign open api";
}
}
SystemForIotChannelInterfaceClient.java
@FeignClient(name = "chain-iot-channel", url = "http://localhost:10020", path = "/iot/channel/open/api")
public interface SystemForIotChannelInterfaceClient extends IotChannelInterfaceApi {
}
最后附上项目结构图