SpringCloud Feign
1.Feign是什么?
Feign 是一个声明web服务客户端,这便得编写web服务客户端更容易,使用Feign 创建一个接口并对它进行注解,它具有可插拔的注解支持包括Feign注解与JAX-RS注解,Feign还支持可插拔的编码器与解码器,Spring Cloud 增加了对 Spring MVC的注解,Spring Web 默认使用了HttpMessageConverters, Spring Cloud 集成 Ribbon 和 Eureka 提供的负载均衡的HTTP客户端 Feign
2.Feign如何使用
通过@EnableFeignClients注释在main方法上,加入容器扫描选项中,开启负载均衡
如下
@SpringBootAppliction
@EnableEurekeClient
@EnableFeignClients
public class ConsumerFeignApplication{
public static void main(String[] args){
SpringApplication.run(ConsumerFeignApplication.class,args);
}
}
定义Feign接口
@FeignClient("demo-provider-user")
public interface FeginClient {
@RequestMapping(value = "/getUser",method = RequestMethod.GET)
String userInfo(@PathVariable String name);
}
入坑说明
- 此处不能用GetMapping、PostMapping,程报请求类型不存在错误
- @PathVariable、@RequestParam 必须要指定参数赋值,否则抛参数不存在错误
- 这里定义的只能是接口,且不需要实现,但是@RequestMapping中的value要和服务提供者里面的方法是一致的,这样才能调得通,方法名可以不一样
- 如果方法里面的参数是复杂对象,fegin默认还是以post方法进行请求
- @FeignClient(“demo-provider-user”)表示开启负载均衡、value是服务提供者的名称
入口调用方如下
@RestController
public class FeginDemoController {
@Autowired
private FeginClient feginClient;
@RequestMapping(value = "/getUser",method = RequestMethod.GET)
public String showInfo(@RequestParam String name){
return feginClient.userInfo(name);
}
}
使用Feign会遇到以下问题
1.Feign第一次请求timeout的问题
application.yml.xml新增feign.hystrix.enabled:false 禁止feign的hystrix
hystrix是一个库,通过添加延迟容忍和容错逻辑,帮助你控制这些分布式服务之间的交互
2.http(requst/response/header)的参数默认不能通过服务传递后获取。如需要通过feign服务传递,可以扩充@FeignClient的configuration()的方法,可自定义参数传递到feign服务中。
3.@FeignClient的fallback()和fallbackFactory可以指定接口进行熔断。
Feign优化如下:
- feign.compression.response.enabled可以指定feign服务返回参数进行压缩,默认不开启。
- feign.compression.request.enabled可以指定feign服务入参参数进行压缩,默认不开启。
- feign.compression.request.mime-types指定服务压缩的类型
- feign.compression.request.min-request-size指定服务压缩数据的最小值,少于最小值不进行压缩。
- 默认feign调用详情日志不打印,调优过程中需要查看详细调用日志,可进行注入@Bean(feignLoggerLevel)更改日志级别(日志级别:FULL/BASIC/HEADERS/NONE,推荐设置FULL全部)
- feign日志可以通过@ConditionalOnProperty注解,默认不开启,可以配置进行开启方便跟踪
后续文章会阐述
作者简介:张程 技术研究
更多文章请关注微信公众号:zachary分解狮 (frankly0423)