打通Feign+Sentinel 测试熔断降级

举报
yd_249383650 发表于 2023/03/06 09:44:47 2023/03/06
【摘要】 ​ 参考文档主页 · alibaba/Sentinel Wiki · GitHubA powerful flow control component enabling reliability, resilience and monitoring for microservices. (面向云原生微服务的高可用流控防护组件) - 主页 · alibaba/Sentinel Wikihttps:...

 参考文档

主页 · alibaba/Sentinel Wiki · GitHubA powerful flow control component enabling reliability, resilience and monitoring for microservices. (面向云原生微服务的高可用流控防护组件) - 主页 · alibaba/Sentinel Wiki https://github.com/alibaba/Sentinel/wiki/%E4%B8%BB%E9%A1%B5

什么是熔断降级 

除了流量控制以外,降低调用链路中的不稳定资源也是 Sentinel 的使命之一。由于调用关 系的复杂性,如果调用链路中的某个资源出现了不稳定,最终会导致请求发生堆积。

编辑

Sentinel 和 Hystrix 的原则是一致的: 当检测到调用链路中某个资源出现不稳定的表现,例如请求响应时间长或异常比例升高的时候,则对这个资源的调用进行限制,让请求快速失败, 避免影响到其它的资源而导致级联故障。 

熔断降级设计理念

在限制的手段上,Sentinel 和 Hystrix 采取了完全不一样的方法。Hystrix 通过 线程池隔离的方式,来对依赖(在 Sentinel 的概念中对应 资源)进行了隔离。这样做的好处是资源和资源之间做到了最彻底的隔离。缺点是除了增加了线程切换的成本(过多的线程池导致线程数目过多),还需要预先给各个资源做线程池大小的分配。

Sentinel 对这个问题采取了两种手段

 通过并发线程数进行限制

和资源池隔离的方法不同,Sentinel 通过限制资源并发线程的数量,来减少不稳定资源对其 它资源的影响。这样不但没有线程切换的损耗,也不需要您预先分配线程池的大小。当某个 资源出现不稳定的情况下,例如响应时间变长,对资源的直接影响就是会造成线程数的逐步 堆积。当线程数在特定资源上堆积到一定的数量之后,对该资源的新请求就会被拒绝。堆积 的线程完成任务后才开始继续接收请求。

 通过响应时间对资源进行降级

除了对并发线程数进行控制以外,Sentinel 还可以通过响应时间来快速降级不稳定的资源。 当依赖的资源出现响应时间过长后,所有对该资源的访问都会被直接拒绝,直到过了指定的 时间窗口之后才重新恢复。

整合测试 

1、引入依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>

2、使用 Nacos 注册中心

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

3、定义 fallback 实现 

public class OrderFeignServiceFallBack implements OrderFeignService {

    @Override
    public Resp<OrderVo> getOrderInfo(String orderSn) {
        return null;
    }
}

4、定义 fallbackfactory 并放在容器中 

@Component
public class OrderFeignFallbackFactory implements
FallbackFactory<OrderFeignServiceFallBack> {
    @Override
    public OrderFeignServiceFallBack create(Throwable throwable) {

        return new OrderFeignServiceFallBack(throwable);
    }
}

5、改造 fallback 类接受异常并实现容错方法 

public class OrderFeignServiceFallBack implements OrderFeignService {

    private Throwable throwable;

    public OrderFeignServiceFallBack(Throwable throwable){

        this.throwable = throwable;
    }

    @Override
    public Resp<OrderVo> getOrderInfo(String orderSn) {
        return Resp.fail(new OrderVo());
    }
}

6、远程接口配置 feign 客户端容错 

@FeignClient(value = "gulimall-oms",fallbackFactory =OrderFeignFallbackFactory.class)
public interface OrderFeignService {

    @GetMapping("/oms/order/bysn/{orderSn}")
    public Resp<OrderVo> getOrderInfo(@PathVariable("orderSn") StringorderSn);
}

7、开启 sentinel 代理 feign 功能;在 application.properties 中配置 

feign.sentinel.enabled=true

 更快的容错方式

1、使用@SentinelResource,并定义 fallback

@SentinelResource(value = "order",fallback = "e")

Fallback 和原方法签名一致,但是最多多一个 Throwable 类型的变量接受异常。

需要给容器中配置注解切面 


@Bean
public SentinelResourceAspect sentinelResourceAspect() {

    return new SentinelResourceAspect();
}

在控制台添加降级策略 

 编辑

2、测试降级效果

当远程服务停止,前几个服务会尝试调用远程服务,满足降级策略条件以后则不会再尝试调 用远程服务






【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。