栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

springCloud-41 Feign实现熔断

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

springCloud-41 Feign实现熔断

Sentinel 适配了 Feign 组件。如果想使用,除了引入 sentinel - starter 的依赖外还需要 2 个步骤:

配置文件打开 sentinel 对 feign 的支持: feign.sentinel.enabled=true 加入 openfeign starter 依赖使 sentinel starter 中的自动化配置类生效: 一,引入依赖

 
    com.alibaba.cloud 
    spring-cloud-starter-alibaba-sentinel 
 
 
    org.springframework.cloud 
    spring-cloud-starter-openfeign 
二,开启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); 

}
四,配置熔断方法
 
@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} 。
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/716478.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号