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功能,设置连接池参数

相关推荐
子洋几秒前
AI Agent 介绍
前端·人工智能·后端
粟悟饭&龟波功1 小时前
【GitHub热门项目精选】(2025-12-19)
前端·人工智能·后端·github
不思念一个荒废的名字1 小时前
【黑马JavaWeb+AI知识梳理】Web后端开发04-登录认证
java·后端
CodeAmaz2 小时前
Spring循环依赖与三级缓存详解
spring·循环依赖·三级缓存
平凡运维之路2 小时前
Linux入侵挖矿处理记录
后端
王中阳Go2 小时前
15 Go Eino AI应用开发实战 | 性能优化
后端·面试·go
shoubepatien2 小时前
JAVA -- 07
java·后端·intellij-idea
王中阳Go2 小时前
09 Go Eino AI应用开发实战 | Hertz Web 框架搭建
人工智能·后端·go
無量3 小时前
ConcurrentHashMap实现原理
java·后端
vipbic3 小时前
Strapi 5 怎么用才够爽?这款插件带你实现“建站自由”
后端·node.js