Feign可以把Rest的请求进行隐藏,伪装成类似SpringMVC的Controller一样。你不用再自己拼接url,拼接参数等等操作,一切都交给Feign去做。
其中支持负载均衡Ribbon、服务熔断Hystix
pom.xml
<!-- feign 内部依赖Ribbon、hystrix 可以不写hystrix依赖 但是Ribbon依赖不可去掉-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
application.yml
feien:
hystrix:
enabled: true #开启熔断处理
ribbon: #负载均衡
ConnectionTimeout: 500 #建立连接时长,超时则抛出异常
ReadTimeout: 2000 #读取数据时长,超过则抛出异常
hystrix:
command:
default:
execution:
isolation:
thread:
timeoutInMilliseconds: 6000
# 设置hystrix的超时时间为6000ms (ConnectionTimeout+ReadTimeout) *2 不能超过timeoutInMilliseconds
- 首先这是一个接口,Feign会通过动态代理,帮我们生成实现类。这点跟mybatis的mapper很像
@FeignClient
,声明这是一个Feign客户端,类似@Mapper
注解。同时通过value
属性指定服务名称- 接口中的定义方法,完全采用SpringMVC的注解,Feign会根据注解帮我们生成URL,并访问获取结果
@FeignClient(value = "user-service",fallback = UserClientFallback.class)
//feign会通过user-service服务名称去eureka注册中心去拉去相应的服务列表
//并通过Ribbon提供的负载均衡算法选取一个服务,继而获得服务的地址,通过GetMapper获得路径出入参数获
//得返回值.
//fallback为熔断处理结果的内容类 实现此接口实现方法。
public interface UserFeignClient {
@GetMapping("/user/{id}")
User queryUserById(@PathVariable("id") Long id);
}
实现类
public class UserClientFallback implements UserClient {
@Override
public String queryById(int id) {
return "服务器忙啊";
}
}
开启feign
@EnableFeignClients //开启feign
@SpringCloudApplication
public class ConsumerApplication {
public static void main(String[] args){
SpringApplication.run(ConsumerApplication.class);
}
}