okhttp 是由 square 公司开源的一个 http 客户端。在 Java 平台上,Java 标准库提供了 HttpURLConnection 类来支持 HTTP 通信。不过 HttpURLConnection 自己的 API 不够友好,所提供的功能也有限。大部分 Java 程序都选择使用 Apache 的开源项目 HttpClient 做为 HTTP 客户端。Apache HttpClient 库的功能强大,使用率也很高。java
okhttp 的设计初衷就是简单和高效,这也是咱们选择它的重要缘由之一。它的优点以下:git
首先介绍一下工程结构,本演示工程包含 provider-server、consumer-server、eureka-server 和 zuul-server 。github
代码清单:chapter19/consumer-server/pom.xmlspring
<dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-okhttp</artifactId> </dependency> </dependencies>
feign-okhttp
这里无需指定版本,目前引入的 feign-okhttp
版本为 10.2.3 ,而 okhttp
的版本为 3.8.1 ,如图:代码清单:chapter19/consumer-server/src/main/resources/application.ymldocker
feign: httpclient: enabled: false okhttp: enabled: true
代码清单:chapter19/consumer-server/src/main/java/com/springcloud/consumerserver/config/OkHttpConfig.java浏览器
@Configuration @ConditionalOnClass(Feign.class) @AutoConfigureBefore(FeignAutoConfiguration.class) public class OkHttpConfig { @Bean public OkHttpClient okHttpClient(){ return new OkHttpClient.Builder() .connectTimeout(30, TimeUnit.SECONDS) .readTimeout(30, TimeUnit.SECONDS) .writeTimeout(30, TimeUnit.SECONDS) .retryOnConnectionFailure(true) .connectionPool(new ConnectionPool(10 , 5L, TimeUnit.MINUTES)) .addInterceptor(new OkHttpLogInterceptor()) .build(); } }
OkHttpClient
注入 Spring 的容器中,这里咱们指定了链接池的大小,最大保持链接数为 10 ,而且在 5 分钟不活动以后被清除。代码清单:缓存
@Slf4j public class OkHttpLogInterceptor implements Interceptor { @Override public Response intercept(Chain chain) throws IOException { log.info("OkHttpUrl : " + chain.request().url()); return chain.proceed(chain.request()); } }
okhttp3.Interceptor
,并非 Spring Boot 中的 Interceptor。远程 Feign 调用代码略过,有须要的读者能够访问 Github 仓库获取。服务器
代码清单:chapter19/zuul-server/pom.xml网络
<dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-okhttp</artifactId> </dependency>
代码清单:chapter19/zuul-server/src/main/resources/application.ymlapp
ribbon: http: client: enabled: false okhttp: enabled: true
咱们修改 idea 启动配置,分别在 8000 和 8001 端口启动 provider-server ,而且顺次启动其他工程,打开浏览器访问连接:http://localhost:8080/consumer/hello ,屡次刷新,能够看到 Hello Spring Cloud! Port : 8000
和 Hello Spring Cloud! Port : 8001
交替书出现,能够证实负载均衡已经成功,能够查看 consumer-server 的日志,以下:
2019-09-23 23:15:27.097 INFO 10536 --- [nio-9000-exec-5] c.s.c.intercepter.OkHttpLogInterceptor : OkHttpUrl : http://host.docker.internal:8001/hello 2019-09-23 23:15:27.593 INFO 10536 --- [nio-9000-exec-6] c.s.c.intercepter.OkHttpLogInterceptor : OkHttpUrl : http://host.docker.internal:8000/hello 2019-09-23 23:15:27.942 INFO 10536 --- [nio-9000-exec-7] c.s.c.intercepter.OkHttpLogInterceptor : OkHttpUrl : http://host.docker.internal:8001/hello 2019-09-23 23:15:28.251 INFO 10536 --- [nio-9000-exec-9] c.s.c.intercepter.OkHttpLogInterceptor : OkHttpUrl : http://host.docker.internal:8000/hello 2019-09-23 23:15:47.877 INFO 10536 --- [nio-9000-exec-8] c.s.c.intercepter.OkHttpLogInterceptor : OkHttpUrl : http://host.docker.internal:8001/hello
能够看到咱们刚才自定义的日志正常打印,证实如今访问确实是经过 okhttp 来进行访问的。