配置文件打开 sentinel 对 feign 的支持: feign.sentinel.enabled=true 加入 openfeign starter 依赖使 sentinel starter 中的自动化配置类生效: 一,引入依赖
二,开启sentinel 支持 在工程的 application.yml 中添加 sentinel 对 feign 的支持com.alibaba.cloud spring-cloud-starter-alibaba-sentinelorg.springframework.cloud spring-cloud-starter-openfeign
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); }四,配置熔断方法
@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} 。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)