Spring Cloud Alibaba微服务从入门到进阶(七)(服务容错-Sentinel)

雪崩效应

我们把基础服务故障,导致上层服务故障,并且这个故障不断放大的过程,成为雪崩效应。
雪崩效应,往往是因为服务没有做好容错造成的。
微服务常见容错方案
仓壁模式

比如让controller有自己独立的线程池,线程池满了就直接拒绝请求
断路器模式

对api进行监控,设置一段时间内的错误率、错误次数。

如果一段时间内达到预值,断路器就会打开,不去调用远程api了。

(断路器模式设计了半开状态,远程api恢复后,断路器可以再次闭合。)
使用Sentinel实现容错

Sentinel是一个实现服务容错的库。

微服务整合sentinel

加依赖(无注解、无配置)
服务整合Sentinel后,通过actuator/sentinel可以访问到
搭建Sentinel控制台
登录,账户/密码 sentinel/sentinel
目前控制台上什么都没有,在服务配置上整合sentinel的控制台地址
调用服务后再刷新控制台,可以看到服务(sentinel和ribbon一样都是懒加载的)
用@SentinelResource注解,进行限流和降级
可以把block/fallback抽离出业务代码,定义单独类
RestTemplate整合Sentinel

使用@SentinelRestTemplate注解

将注解加在服务初始化类上,就可以给RestTemplate整合Sentinel了
写测试代码(就是使用feign之前的那段代码)
查看sentinel控制台->簇点电路
多出来的两行就是@SentinelRestTemplate注解支持的。

RestTemplate整合Sentinel还提供了一个开关resttemplate.sentinel.enabled
Feign整合Sentinel

只需要添加配置 feign.sentinel.enabled = true
Sentinel控制台结果和上面整合RestTemplate效果一下
如果服务被流控了,不想抛异常,

可以在UserCenterFeignClient接口@FeignClient注解上指定fallback参数到指定的类上
该类实现UserCenterFeignClient接口
配置sentinel流控规则,实现效果是"一个默认用户",而不是抛异常了
Sentinel使用总结

相关推荐
数据要素X2 小时前
寻梦数据空间 | 架构篇:从概念到落地的技术实践与突破性创新
大数据·运维·数据仓库·微服务·数据治理·数据中台·可信数据空间
法欧特斯卡雷特3 小时前
从 Kotlin 编译器 API 的变化开始: 2.2.2X -> 2.3.0-Beta1
后端·架构·开源
@HNUSTer4 小时前
基于 GEE 平台用 Sentinel-1 SAR 数据实现山区潜在滑坡检测
云计算·sentinel·数据集·遥感大数据·gee·云平台·sar
Light605 小时前
领码方案|微服务与SOA的世纪对话(6):组织跃迁——智能架构下的团队与文化变革
微服务·云原生·ddd边界·组织双生体·pod协同·文化仪式·ai自演进
柳贯一(逆流河版)5 小时前
Nacos 实战指南:微服务下服务注册与配置管理的完整落地
java·微服务·架构
一叶飘零_sweeeet5 小时前
从 “黑盒“ 到 “透明“:SkyWalking 实战指南 —— 让微服务问题无所遁形
分布式·微服务·skywalking·分布式链路追踪
盗德6 小时前
为什么要用Monorepo管理前端项目?(详解)
前端·架构·代码规范
koddnty7 小时前
协程退出与智能指针
后端·架构
yuzhiboyouye9 小时前
前端架构师,是架构什么
前端·架构
用户939509544139910 小时前
全开源点餐系统源码全解析:从架构设计到部署实践的完整指南
架构