目录
1 前言
我们可以利用RestTemplate实现服务的远程调用,但是远程调用的代码太复杂了。因此我们需要使用OpenFeign来使我们的操作更加便捷和优雅。
2 使用方法
2.1 Nacos的部署
详情可看本人的这篇文章《Nacos注册中心的部署及使用(超详细)》,如果已经完成Nacos的部署及相关依赖的引入看,可跳过这一步。
2.2 引入相关依赖
<!--openFeign-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<!--负载均衡器-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>
如果你问我为什么没有版本号,那是因为这两个依赖帮我们管理了SpringCloud绝大多数依赖的版本,就像SpringBoot一样,如下:
<!--spring cloud-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>2021.0.3</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<!--spring cloud alibaba-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>2021.0.4.0</version>
<type>pom</type>
<scope>import</scope>
</dependency>
2.3 开启OpenFeign功能
在启动类上添加注解@EnableFeignClients,如下:
//其它代码
@EnableFeignClients
public class ItemApplication {
public static void main(String[] args) {
SpringApplication.run(ItemApplication.class, args);
}
}
2.4 编写OpenFeign客户端
//item-service为服务名
@FeignClient(value = "item-service")
public interface ItemClient {
//以Get方式访问/item接口
@GetMapping("/item")
//返回值类型为List<ItemDTO>;参数名为ids,参数类型为Collection<Long>
List<ItemDTO> queryItemByIds(@RequestParam("ids") Collection<Long> ids);
}
无需实现,和Mapper层方法差不多,实现交给组件自己去做。实际上是调用item-service服务中控制层的方法。
2.5 使用OpenFeign客户端
@Service
@RequiredArgsConstructor // Lombok提供的注解,用于自动生成构造函数
public class CartServiceImpl extends ServiceImpl<CartMapper, Cart> implements ICartService {
//注入依赖
private final ItemClient itemClient;
private void handleCartItems(List<CartVO> vos) {
//其它代码
List<ItemDTO> items = itemClient.queryItemByIds(itemIds);
//其它代码
}
}
3 性能优化
OpenFeign底层每次都要创建连接,效率较低,因此我们可以使用其它组件对其优化。
3.1 引入依赖
<!--OK http 的依赖 -->
<dependency>
<groupId>io.github.openfeign</groupId>
<artifactId>feign-okhttp</artifactId>
</dependency>
3.2 开启连接池
feign:
okhttp:
enabled: true # 开启OKHttp功能