Feign组件
是Netflix开发的声明试、模板化的HTTP客户端,更加便捷、优雅的调用HTTP的API;内部集成了Ribbon,与之不同的是,feign只需要定义服务绑定接口且声明的方法,实现服务的调用。
spring Cloud 在Feign的基础上实现了OpenFeign支持了Spring mvc的注解。
Feign依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
</dependency>
OpenFeign依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
二:简单使用实战
@FeignClient(value = "mall-order",path = "/order")
public interface OrderFeignService {
@RequestMapping("/findOrderByUserId/{userId}")
R findOrderByUserId(@PathVariable("userId") Integer userId);
}
在启动类添加注解:
@EnableFeignClients
三:拦截器配置
通常我们调用接口都是有权限控制的。
3.1Basic认证
@Bean
public BasicAuthRequestInterceptor basicAuthRequestInterceptor() {
return new BasicAuthRequestInterceptor("Authorization", "123456");
}
3.2RequestInterceptor认证(推荐)
每次feign发起HTTP调用之前,都会执行拦截器中的逻辑
public class FeignAuthRequestInterceptor implements RequestInterceptor {
@Override
public void apply(RequestTemplate template) {
// 业务逻辑 模拟认证逻辑
String access_token = UUID.randomUUID().toString();
template.header("Authorization",access_token);
}
}
3.3在yaml配置文件中配置
feign:
client:
config:
mall-order:
requestInterceptors[0]: #配置拦截器
com.**.***.interceptor.FeignAuthRequestInterceptor
四:超时时间配置
@Bean
public Request.Options options(){
return new Request.Options(5000, 5000);
}
通过 Options 可以配置连接超时时间和读取超时时间,Options 的第一个参数是连接的超时时间(ms), 默认值是 2s;第二个是请求处理的超时时间(ms),默认值是 5s。
Feign的底层用的是Ribbon,但超时时间以Feign配置为准
五:从Open Feign迁移到Dubbo
使用 @DubboTransported 注解,就可以实现 从 openFeign 迁移到 Dubbo
@FeignClient(value = "mall-order",path = "/order")
@DubboTransported(protocol = "dubbo")
public interface OrderFeignService {
@RequestMapping("/findOrderByUserId/{userId}")
R findOrderByUserId(@PathVariable("userId") Integer userId);
}