SpringCloud开发实战(五):Feign的一些优化建议

目录
SpringCloud开发实战(一):搭建SpringCloud框架
SpringCloud开发实战(二):通过RestTemplate实现远程调用
SpringCloud开发实战(三):集成Eureka注册中心
SpringCloud开发实战(四):Feign远程调用

前言

我们在SpringCloud开发实战(四):Feign远程调用 这篇文章中使用Feign来替代RestTemplate实现远程调用。但是默认的Feign其实还有可以优化的空间。

因为Feign底层发起Http请求,实际上是依赖于其他的框架来实现的。其底层客户端实现包括:

  • URLConnection:默认实现,不支持连接池
  • Apache HttpClient :支持连接池
  • OKHttp:支持连接池

因此提高Feign的性能主要手段就是使用连接池代替默认的URLConnection。这里我们用Apache的HttpClient来演示。

一、引入依赖

我们在order-service的pom文件中引入Apache的HttpClient依赖:

java 复制代码
<!--httpClient的依赖 -->
<dependency>
    <groupId>io.github.openfeign</groupId>
    <artifactId>feign-httpclient</artifactId>
</dependency>

二、配置连接池

我们在order-service的application.yml中添加配置:

java 复制代码
feign:
  client:
    config:
      default: # default全局的配置
        loggerLevel: BASIC # 日志级别,BASIC就是基本的请求和响应信息
  httpclient:
    enabled: true # 开启feign对HttpClient的支持
    max-connections: 200 # 最大的连接数
    max-connections-per-route: 50 # 每个路径的最大连接数

三、测试

接下来,我们在FeignClientFactoryBean中的loadBalance方法中打断点,鼠标移动在openfeign上,然后按Ctrl+鼠标左键

然后会自动跳到openfeign包,然后我们找到FeignClientFactoryBean,双击打开

接下来,在FeignClientFactoryBean中的loadBalance方法中打断点:

接着我们通过Debug方式启动order-service服务,然后调用接口,可以看到这里的client,底层就是Apache HttpClient:

四、总结

最后我们来总结一下Feign的优化:

  1. 日志级别尽量用basic

  2. 使用HttpClient或OKHttp代替URLConnection

    • 引入feign-httpClient依赖

    • 配置文件开启httpClient功能,设置连接池参数

相关推荐
咖啡啡不加糖1 小时前
Redis大key产生、排查与优化实践
java·数据库·redis·后端·缓存
大鸡腿同学1 小时前
纳瓦尔宝典
后端
2302_809798323 小时前
【JavaWeb】Docker项目部署
java·运维·后端·青少年编程·docker·容器
zhojiew3 小时前
关于akka官方quickstart示例程序(scala)的记录
后端·scala
sclibingqing3 小时前
SpringBoot项目接口集中测试方法及实现
java·spring boot·后端
JohnYan5 小时前
Bun技术评估 - 03 HTTP Server
javascript·后端·bun
周末程序猿5 小时前
Linux高性能网络编程十谈|C++11实现22种高并发模型
后端·面试
ZHOU_WUYI5 小时前
Flask与Celery 项目应用(shared_task使用)
后端·python·flask
忠于明白5 小时前
Spring AI 核心工作流
人工智能·spring·大模型应用开发·spring ai·ai 应用商业化