Feign底层的客户端实现:
• URLConnection :默认实现,不支持连接池• Apache HttpClient :支持连接池• OKHttp :支持连接池
因此优化Feign的性能主要包括:
1、使用连接池代替默认的URLConnection
2、日志级别,最好用basic或none
Feign的性能优化-连接池配置
Feign添加HttpClient的支持,引入依赖:
<!--httpClient的依赖 --> <dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-httpclient</artifactId> </dependency>
配置文件开启httpClient功能,设置连接池参数 :
feign: httpclient: enabled: true #支持 HttpClient的开关 max-connections: 200 # 最大连接数 max-connections-per-route: 50 #单个路径的最大连接数
Feign的最佳实践
方式一:让controller和FeignClient继承同一接口
方式二:将FeignClient、POJO、Feign的默认配置都定义到一个项目中,供所有消费者使用
实现最佳实践方式二的步骤如下:
1.首先创建一个module,命名为feign-api,然后引入feign的starter依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
2.将order-service中编写的UserClient、User、DefaultFeignConfiguration都复制到feign-api项目中
3.在order-service中引入feign-api的依赖(上面封装的)
4.修改order-service中的所有与上述三个组件有关的import部分,改成导入feign-api中的包
5.重启测试
因为将原有项目中的工具类放到另一个封装项目中,spring无法通过注解获取
方式一:在启动类注解上指定FeignClient所在包
@EnableFeignClients(basePackages = "cn.itcast.feign.clients")
方式二:指定FeignClient字节码
@EnableFeignClients(clients = {UserClient.class})