OpenFeign 是 Spring 官方推出的一种声明式服务调用和负载均衡组件。它的出现就是为了替代已经进入停更维护状态的 Netflix Feign,是目前微服务间请求的常用通讯组件。
OpenFeign 底层依赖Ribbon 框架,并且使用了 Ribbon 的请求连接超时时间和请求处理超时时间作为其超时时间,可以通过配置修改。
通过修改 Ribbon 的超时时间:
ribbon:
ReadTimeout: 5000
ConnectionTimeout: 10000
直接修改 OpenFeign配置:
feign:
client:
config:
default:
connectTimeout:
readTimeout:
OpenFeign 底层通信组件默认使用 JDK 自带的 URLConnection 对象进行 HTTP 请求的,因为没有使用连接池,所以性能不是很好。我们可以将 OpenFeign 的通讯组件,手动替换成像 Apache HttpClient 或 OKHttp 这样的专用通信组件,这些的专用通信组件自带连接池可以更好地对 HTTP 连接对象进行重用与管理,同时也能大大提升 HTTP 请求的效率。接下来我以 Apache HttpClient 为例,演示一下专用通讯组件的使用。
在项目的依赖管理文件 pom.xml 中添加以下配置:
<dependency>
<groupId>org.springframework.cloudgroupId>
<artifactId>spring-cloud-starter-openfeignartifactId>
dependency>
<dependency>
<groupId>io.github.openfeigngroupId>
<artifactId>feign-httpclientartifactId>
dependency>
启动 Apache HttpClient 组件,在项目配置文件 application.yml 中添加以下配置:
feign:
client:
httpclient: # 开启 HttpClient
enabled: true
OpenFeign 默认不会开启数据压缩功能,但我们可以手动的开启它的 Gzip 压缩功能,这样可以极大的提高宽带利用率和加速数据的传输速度,在项目配置文件 application.yml 中添加以下配置:
feign:
compression:
request:
enabled: true
mime-types: text/xml,application/xml, application/json
min-request-size: 1024
response:
enabled: true
OpenFeign 底层使用的是 Ribbon 做负载均衡的,它默认的负载均衡策略是轮询策略。
除了轮询策略之外,我们还有其他 6 种内置的负载均衡策略可以选择,这些负载均衡策略如下:
@Configuration
public class MyRuleConfig {
@Bean
@LoadBalanced
public IRule myRule(){
return new RandomRule();
}
}
OpenFeign 是 Spring 官方推出的一种声明式服务调用和负载均衡组件,在生产环境中我们可以按照业务需要按需进行配置调整以求达到最好的性能。
想要获取更多Java开发相关材料,请微信搜**【小白技术圈】**阅读,发送回复 G02获取Java经典面试题!欢迎大大们催更。






