OpenFeign的使用及性能优化

本文介绍了如何使用OpenFeign在SpringCloud中进行服务调用,包括Nacos部署、依赖引入、启用OpenFeign功能、编写和使用客户端,以及如何通过OKHttp连接池进行性能优化。
摘要由CSDN通过智能技术生成

目录

1 前言

2 使用方法

2.1 Nacos的部署

2.2 引入相关依赖

2.3 开启OpenFeign功能

2.4 编写OpenFeign客户端

2.5 使用OpenFeign客户端

3 性能优化

3.1 引入依赖

3.2 开启连接池


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功能
  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
对于OpenFeign性能优化,可以考虑以下几个方面: 1. 合理使用连接池:OpenFeign默认使用了Apache HttpClient作为HTTP客户端,可以通过配置连接池来提高性能。可以增加`maxConnections`和`maxConnectionsPerRoute`参数来调整连接池大小,以适应并发请求。 2. 启用GZIP压缩:OpenFeign支持请求和响应的GZIP压缩,可以通过设置`Content-Encoding`和`Accept-Encoding`头来启用压缩。这样可以减少网络传输的数据量,提高性能。 3. 避免重复解析:OpenFeign默认使用Jackson进行JSON解析,可以通过使用更高效的解析库如Fastjson或Gson来减少解析时间。 4. 启用请求/响应日志:通过启用请求和响应的日志,可以帮助我们定位潜在的性能问题。可以通过设置`logging.level.<package>.<class>=DEBUG`来启用详细的日志输出。 5. 设置超时时间:根据实际需求,合理设置连接超时和读取超时时间,避免长时间的阻塞。 6. 缓存策略:对于一些不经常变化的数据,可以考虑使用缓存来减少对后端服务的请求。可以使用框架如Redis或Guava来实现缓存。 7. 并发控制:如果需要同时发起多个请求,可以使用并发控制机制如信号量或线程池来限制并发数量,避免过多的请求导致性能下降。 需要注意的是,性能优化是一个综合考虑的过程,需要根据具体的业务场景和需求进行调整和优化。以上只是一些常见的优化措施,具体还需要根据实际情况进行进一步的分析和调整。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

厂里英才

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值