SpringCloud Alibaba——Sentinel服务熔断与限流(五、服务熔断)

简介: SpringCloud Alibaba——Sentinel服务熔断与限流(五、服务熔断)

1.开篇



前面那四篇文章,基本上都是在聊sentinel中有关限流降级的内容,现在该聊聊sentinel中的服务熔断了。

内容大致就是 @SentinelResource 注解中的fallback属性,同时分别整合RibbonOpenFeign

2.项目源码


github源码地址:https://github.com/2656307671/SpringCloud-Alibaba-Sentinel

gitee源码地址:https://gitee.com/szh-forever-young/SpringCloud-Alibaba-Sentinel

下面的测试对应了git仓库中的9003900484这三个微服务模块。前提是nacos启动成功、sentinel启动成功。先对90039004中的请求 /paymentSQL/{id} 进行一次访问。可以正常拿到数据,说明微服务提供者启动成功。


2.1 Sentinel + Ribbon


测试完90039004之后,我们启动84微服务消费者模块,因为nacos默认集成了ribbon,所以这里访问 /consumer/fallback/{id} 自然是一次9003、一次9004,已经实现了负载均衡。


2.1.1 只配置fallback

下面来说服务熔断,就要通过 @SentinelResource 注解中的fallback属性来配置。如果我们什么都不配,注解中只写一个标注服务熔断的唯一名称value属性,那么此时如果出错,反馈给用户的将会是error page,看上去很不友好。

所以这里在 @SentinelResource 注解中进行fallback属性的配置,详情参考仓库代码。配置了fallback之后再访问,由于id=45这两个值我没有添加,所以访问必然出错,但我们配置了fallback属性,此时出错就会走fallback对应的兜底方法。


2.1.2 只配置blockHandler


上面的案例只配置了fallback,可以看到出错之后会走fallback中定义的兜底方法。

下面演示只配置blockHandler的情况。当异常数达到两次之后,未来2秒的时间窗口内,将转向blockHandler中定义的降级限流方法。


2.1.3 fallbackblockHandler都配置

因为blockHandler负责的是在sentinel页面中的降级限流,所以我们这里先对fallback请求方法做一个配置。QPS > 1 则触发blockHandler的降级限流。


id=1,数据存在,正常情况下1s内访问1次,是可以拿到数据的。

下面这张图是我在1s内访问了多次,则满足配置 QPS > 1,触发blockHandler相关的降级限流方法。


id=4,数据不存在,访问之后直接会报 IllegalArgumentException 非法参数异常,而我们的@SentinelResource注解中的fallback属性可以来处理该异常信息,此时不再返回error page,而是返回fallback中定义的兜底方法。


上面的截图1s内只访问了1id=4这个请求,下面我1s内访问多次,此时满足 QPS > 1,直接触发blockHandler相关的降级限流方法。


根据fallbackblockHandler都配置的情况,我们可以得出结论:👇👇👇

·       fallback管理Java中的运行时异常信息,如果出现异常,则走fallback中定义的兜底方法。

·       blockHandler一般需要在sentinel中进行配置,只要你满足了QPS、异常数等这些配置信息,一定走blockHandler中定义的降级限流方法。

·       例如上面的案例,异常1s内出现1次,则走fallback1s内超过1次,则走blockHandler


2.2 Sentinel + OpenFeign


使用Sentinel集成OpenFeign了话,首先要做一些修改。


1.    因为nacos默认继承了ribbon,所以sentinel中可以直接使用ribbon,不用再添加ribbon依赖。但是openfeign不一样,需要pom中额外添加openfeign的依赖。

2.    yml配置文件中,激活sentinelopenfeign的支持。

3.    连接服务提供者的业务接口上需要添加 @FeignClient 注解等相关配置信息。

4.    主启动类上添加@EnableFeignClients 注解表示开启对OpenFeign的支持。


下面就做一个简单的测试了,需要启动84微服务消费者、9004微服务提供者。进行一次访问,可以拿到数据。


此时将9004微服务提供者停掉,再次访问,可以看到84微服务消费者进行了自动降级,也就是找不到微服务提供者9004,会去找连接服务提供者的业务接口,根据业务接口上的 @FeignClient 注解等相关配置信息,找到相应的接口实现类中的降级方法,进行自动降级。

相关文章
|
2月前
|
人工智能 SpringCloudAlibaba 自然语言处理
SpringCloud Alibaba AI整合DeepSeek落地AI项目实战
在现代软件开发领域,微服务架构因其灵活性、可扩展性和模块化特性而受到广泛欢迎。微服务架构通过将大型应用程序拆分为多个小型、独立的服务,每个服务运行在其独立的进程中,服务与服务间通过轻量级通信机制(通常是HTTP API)进行通信。这种架构模式有助于提升系统的可维护性、可扩展性和开发效率。
555 1
|
29天前
|
负载均衡 Dubbo Java
Spring Cloud Alibaba与Spring Cloud区别和联系?
Spring Cloud Alibaba与Spring Cloud区别和联系?
|
3月前
|
人工智能 安全 Java
AI 时代:从 Spring Cloud Alibaba 到 Spring AI Alibaba
本次分享由阿里云智能集团云原生微服务技术负责人李艳林主讲,主题为“AI时代:从Spring Cloud Alibaba到Spring AI Alibaba”。内容涵盖应用架构演进、AI agent框架发展趋势及Spring AI Alibaba的重磅发布。分享介绍了AI原生架构与传统架构的融合,强调了API优先、事件驱动和AI运维的重要性。同时,详细解析了Spring AI Alibaba的三层抽象设计,包括模型支持、工作流智能体编排及生产可用性构建能力,确保安全合规、高效部署与可观测性。最后,结合实际案例展示了如何利用私域数据优化AI应用,提升业务价值。
307 4
|
8月前
|
Java UED Sentinel
微服务守护神:Spring Cloud Sentinel,让你的系统在流量洪峰中稳如磐石!
【8月更文挑战第29天】Spring Cloud Sentinel结合了阿里巴巴Sentinel的流控、降级、熔断和热点规则等特性,为微服务架构下的应用提供了一套完整的流量控制解决方案。它能够有效应对突发流量,保护服务稳定性,避免雪崩效应,确保系统在高并发下健康运行。通过简单的配置和注解即可实现高效流量控制,适用于高并发场景、依赖服务不稳定及资源保护等多种情况,显著提升系统健壮性和用户体验。
160 1
|
10月前
|
监控 Java Sentinel
使用Sentinel进行服务调用的熔断和限流管理(SpringCloud2023实战)
Sentinel是面向分布式、多语言异构化服务架构的流量治理组件,主要以流量为切入点,从流量路由、流量控制、流量整形、熔断降级、系统自适应过载保护、热点流量防护等多个维度来帮助开发者保障微服务的稳定性。
245 3
|
6月前
|
负载均衡 算法 Java
蚂蚁面试:Nacos、Sentinel了解吗?Springcloud 核心底层原理,你知道多少?
40岁老架构师尼恩分享了关于SpringCloud核心组件的底层原理,特别是针对蚂蚁集团面试中常见的面试题进行了详细解析。内容涵盖了Nacos注册中心的AP/CP模式、Distro和Raft分布式协议、Sentinel的高可用组件、负载均衡组件的实现原理等。尼恩强调了系统化学习的重要性,推荐了《尼恩Java面试宝典PDF》等资料,帮助读者更好地准备面试,提高技术实力,最终实现“offer自由”。更多技术资料和指导,可关注公众号【技术自由圈】获取。
蚂蚁面试:Nacos、Sentinel了解吗?Springcloud 核心底层原理,你知道多少?
|
7月前
|
监控 Java Nacos
SpringCloud基础5——微服务保护、Sentinel
sentinel、雪崩问题、流量控制、隔离和降级、授权规则、规则持久化
SpringCloud基础5——微服务保护、Sentinel
|
9月前
|
监控 Java 应用服务中间件
SpringCloud面试之流量控制组件Sentinel详解
SpringCloud面试之流量控制组件Sentinel详解
426 0
|
10月前
|
Java 开发者 Sentinel
Spring Cloud系列——使用Sentinel进行微服务保护
Spring Cloud系列——使用Sentinel进行微服务保护
98 5
|
9月前
|
监控 Dubbo 应用服务中间件
通用快照方案问题之Sentinel与SpringCloud和Dubbo的整合如何解决
通用快照方案问题之Sentinel与SpringCloud和Dubbo的整合如何解决
83 0