Sentinel
适配了
Feign
组件。如果想使用,除了引入
sentinel
-
starter
的依赖外还需要
2
个步骤:
- 配置文件打开 sentinel 对 feign 的支持: feign.sentinel.enabled=true
- 加入 openfeign starter 依赖使 sentinel starter 中的自动化配置类生效:
一,引入依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
二,开启sentinel 支持
在工程的
application.yml
中添加
sentinel
对
feign
的支持
feign:
sentinel:
enabled: true
三,配置FeignClient
和使用
Hystrix
的方式基本一致,需要配置
FeignClient
接口以及通过
fallback
指定熔断降级方法
//指定需要调用的微服务名称
@FeignClient(name="shop-service-product",fallback = ProductFeginClientCallBack.class) public interface ProductFeginClient {
//调用的请求路径
@RequestMapping(value = "/product/{id}",method = RequestMethod.GET)
public Product findById(@PathVariable("id") Long id);
}
四,配置熔断方法
/***
实现自定义的ProductFeginClient接口
* 在接口实现类中编写熔断降级方法
*/
@Component
public class ProductFeginClientCallBack implements ProductFeginClient {
/*** 降级方法 */
public Product findById(Long id) {
Product product = new Product();
product.setId(-1l);
product.setProductName("熔断:触发降级方法");
return product;
}
}
Feign
对应的接口中的资源名策略定义:
httpmethod:protocol://requesturl
。
@FeignClient
注解中
的所有属性,
Sentinel
都做了兼容。
ProductFeginClient
接口中方法
fifindById
对应的资源名为
GET:
http://shop-service
product/product/
{str}
。