1. 概述
版本:
spring-boot: 1.5.9.RELEASE
spring-cloud: Dalston.SR5
在默认情况下 spring cloud feign在进行各个子服务之间的调用时,http组件使用的是jdk的HttpURLConnection,没有使用线程池。 可通过为feign配置http线程池优化调用效率。
2.OkHttp简介
OkHttp 是一个高效的 HTTP 客户端,具有非常多的优势:
- 能够高效的执行 http,数据加载速度更快,更省流量
- 支持 GZIP 压缩,提升速度,节省流量
- 缓存响应数据,避免了重复的网络请求
- 使用简单,支持同步阻塞调用和带回调的异步调用
- 当网络出现问题的时候OkHttp依然坚守自己的职责,它会自动恢复一般的连接问题,如果你的服务有多个IP地址,当第一个IP请求失败时,OkHttp会交替尝试你配置的其他IP,OkHttp使用现代TLS技术(SNI, ALPN)初始化新的连接,当握手失败时会回退到TLS 1.0。
3. 配置方式:
i) 引入jar包
gradle方式: compile 'io.github.openfeign:feign-okhttp'
maven方式:
<dependency>
<groupId>io.github.openfeign</groupId>
<artifactId>feign-okhttp</artifactId>
</dependency>
ii) application.yml
feign.okhttp.enabled=true
iii) okhttp连接对象的初始化
建议在spring容器中以bean的形式生成,代码如下:
1 @Configuration 2 @ConditionalOnClass(Feign.class) 3 @AutoConfigureBefore(FeignAutoConfiguration.class) 4 public class FeignOkHttpConfig{ 5 6 @Bean 7 public okhttp3.OkHttpClient okHttpClient(){ 8 return new okhttp3.OkHttpClient.Builder() 9 .readTimeout(60,TimeUnit.SECONDS) 10 .connectTimeout(60,TimeUnit.SECONDS) 11 .connectionPool(new ConnectionPool()) 12 .build(); 13 } 14 }
验证部分:
OkHttpClient.java # execute方法添加断点, 前端执行一个可以发出feign调用的请求,看断点是否落在execute方法中。
如果成功落入断点部分,那么恭喜你了!
如果没有进入断点部分,那么你可要好好检查一下代码!