Feign
简介
(Feign = RestTemplate+Ribbon+Hystrix )
Feign是Netflix开发的⼀个轻量级RESTful的HTTP服务客户端(⽤它来发起请求,远程调⽤的)
类似dubbo,服务消费者拿到提供者的接口,像调用本地方法一样调用接口中的方法,实际发出的是远程的请求。
本质:封装了http调用流程,更符合面向接口化的编程习惯
/**
* 1.name属性用于指定要调用微服务的名称,对应在注册中心的名称。
* 2.openFeign支持springmvc注解,接口中的方法相当于远程服务controller的handler方法。
* 3.使用接口中的方法完成远程调用(注入接口接口,实际注入的是实现类)
* @author renpeiqian
* @date 2021/7/15 14:51
* @since
*/
@FeignClient(name = "lagou-service-resume")
public interface ResumeServiceApi {
/**
* @Description 使用Feign调用简历服务接口
* @Param [userId] 用户id
* @return java.lang.Integer
*/
@RequestMapping(value = "/resume/state/{userId}",method = RequestMethod.GET)
Integer check(@PathVariable(value = "userId") Long userId);
}
复杂均衡
Feign集成了Ribbon依赖和自动配置,可以通过ribbon配置修改负载均衡策略。
熔断器
熔断器默认是关闭,需要在配置文件中开启
feign:
#开启熔断器
hystrix:
enabled: true
注意点:
- 开启熔断器后,feign中所有方法都会被加入容错机制,一旦出现错误,就会执行回退逻辑
- feign、hystrix都有超时时间设置,同时设置时以两者之间的值为准。
Fegin集成hystrix
1.编写Fallbak类,实现FeignClient接口
/**
* 简历微服务回调类 :用于简历微服务不可用或者响应时间过长,发生熔断机制后回调,给予用户后者消费者错误信息
* @author renpeiqian
* @date 2021/7/15 15:59
* @since
*/
@Component //注入ioc容器
public class ResumeServiceFallBack implements ResumeServiceApi {
@Override
public Integer check(Long userId) {
return -6;
}
}
2.在接口中引入fallback类
@FeignClient(name = "lagou-service-resume" ,fallback = ResumeServiceFallBack.class)
@RequestMapping("/resume")
//在引入fallbak类 ,需将requestMapping写入feignclient的path中
//@FeignClient(name = "lagou-service-resume" ,fallback = ResumeServiceFallBack.class,path="/resum")
@RequestMapping("/resume")
public interface ResumeServiceApi {
/**
* @Description 使用Feign调用简历服务接口
* @Param [userId] 用户id
* @return java.lang.Integer
*/
@RequestMapping(value = "/resume/state/{userId}",method = RequestMethod.GET)
Integer check(@PathVariable(value = "userId") Long userId);
}
请求和响应压缩
Feign ⽀持对请求和响应进⾏GZIP压缩,以减少通信过程中的性能损耗。
feign:
compression:
request:
enabled: true # 开启请求压缩
mime-types: text/html,application/xml,application/json # 设置压缩的数据类型,此处也是默认值
min-request-size: 2048 # 设置触发压缩的⼤⼩下限,此处也是默认值
response:
enabled: true # 开启响应压缩
日志配置
Feign是http请求客户端,在请求和响应的时候,可以打印出比较详细的日志。(请求头、请求体等)
默认日志是没有开启的。
1.开启Feign⽇志功能及级别
/**
* @author renpeiqian
* @date 2021/7/15 16:21
* @since
*/
@Configuration
public class FeignConfig {
/**
* @Description
* Feign日志级别(请求过程信息)
* NONE:默认的,不显示任何⽇志----性能最好
* BASIC:仅记录请求⽅法、 URL、响应状态码以及执⾏时间----⽣产问题追踪
* HEADERS:在BASIC级别的基础上,记录请求和响应的header
* FULL:记录请求和响应的header、 body和元数据----适⽤于开发及测试环境定位问题
* @Param []
* @return feign.Logger.Level
*/
@Bean
Logger.Level feignLevel() {
return Logger.Level.FULL;
}
}
2.配置系统log⽇志级别为debug
logging:
level:
# Feign⽇志只会对⽇志级别为debug的做出响应
com.lagou.edu.api.ResumeServiceApi:
debug
源码分析
采用jdk动态代理,对方法增强。底层请求发起是HttpURLConnection
//todo