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