当前位置: 首页 > news >正文

Sentinel学习

微服务保护的方案有很多,比如:

  • 请求限流
  • 线程隔离
  • 服务熔断

这些方案或多或少都会导致服务的体验上略有下降,比如请求限流,降低了并发上限;线程隔离,降低了可用资源数量;服务熔断,降低了服务的完整度,部分服务变的不可用或弱可用。因此这些方案都属于服务降级的方案。但通过这些方案,服务的健壮性得到了提升。

Sentinel 具有以下特征:

  • 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应用等。
  • 完备的实时监控:Sentinel 同时提供实时的监控功能。您可以在控制台中看到接入应用的单台机器秒级数据,甚至 500 台以下规模的集群的汇总运行情况。
  • 广泛的开源生态:Sentinel 提供开箱即用的与其它开源框架/库的整合模块,例如与 Spring Cloud、Apache Dubbo、gRPC、Quarkus 的整合。您只需要引入相应的依赖并进行简单的配置即可快速地接入 Sentinel。同时 Sentinel 提供 Java/Go/C++ 等多语言的原生实现。
  • 完善的 SPI 扩展机制:Sentinel 提供简单易用、完善的 SPI 扩展接口。您可以通过实现扩展接口来快速地定制逻辑。例如定制规则管理、适配动态数据源等。

接下来我们从Sentinel学习微服务的服务保护内容

请求限流

服务故障最重要原因,就是并发太高!解决了这个问题,就能避免大部分故障。当然,接口的并发不是一直很高,而是突发的。因此请求限流,就是限制或控制接口访问的并发流量,避免服务因流量激增而出现故障。

线程隔离

当一个业务接口响应时间长,而且并发高时,就可能耗尽服务器的线程资源,导致服务内的其它接口受到影响。所以我们必须把这种影响降低,或者缩减影响的范围。线程隔离正是解决这个问题的好办法。

为了避免某个接口故障或压力过大导致整个服务不可用,我们可以限定每个接口可以使用的资源范围,也就是将其“隔离”起来。

如图所示,我们给查询购物车业务限定可用线程数量上限为20,这样即便查询购物车的请求因为查询商品服务而出现故障,也不会导致服务器的线程资源被耗尽,不会影响到其它接口。

服务熔断

线程隔离虽然避免了雪崩问题,但故障服务(商品服务)依然会拖慢购物车服务(服务调用方)的接口响应速度。而且商品查询的故障依然会导致查询购物车功能出现故障,购物车业务也变的不可用了。

处理方法:

  • 编写服务降级逻辑:就是服务调用失败后的处理逻辑,根据业务场景,可以抛出异常,也可以返回友好提示或默认数据。
  • 异常统计和熔断:统计服务提供方的异常比例,当比例过高表明该接口会影响到其它服务,应该拒绝调用该接口,而是直接走降级逻辑。

给FeignClient编写失败后的降级逻辑有两种方式:

  • 方式一:FallbackClass,无法对远程调用的异常做处理
  • 方式二:FallbackFactory,可以对远程调用的异常做处理,我们一般选择这种方式。

我们选择编写FallbackFactory:

步骤一:在hm-api模块中给ItemClient定义降级处理类,实现FallbackFactory:

步骤二:在hm-api模块中的com.hmall.api.config.DefaultFeignConfig类中将ItemClientFallback注册为一个Bean:

步骤三:在hm-api模块中的ItemClient接口中使用ItemClientFallbackFactory:

Sentinel中的断路器不仅可以统计某个接口的慢请求比例,还可以统计异常请求比例。当这些比例超出阈值时,就会熔断该接口,即拦截访问该接口的一切请求,降级处理;当该接口恢复正常时,再放行对于该接口的请求。

http://www.jsqmd.com/news/505419/

相关文章:

  • git 怎么导出提交历史,文件是乱码
  • 173.6亿元!2032年半导体材料回收市场规模锁定,资源再生产业迎来新增长极
  • 教程】利用MATLAB绘制分布式电源配电网模型图,详解故障点设置与短路波形显示,实现电压电流的...
  • ms-swift保姆级教程:从安装到微调,小白也能轻松上手
  • Llava-v1.6-7b医疗应用:医学影像报告自动生成系统
  • 全球隐私控制(GPC):隐私保护新利器的机遇与挑战
  • SEO_10个提升网站排名的实用SEO技巧分享(80 )
  • Vivado 2023.1与VCS/Verdi 2022版本跨版本联合仿真实战指南
  • Transformer跨界玩转多模态:MulT模型在语音+视频+文本分析中的5个实战技巧
  • 金仓数据库在文档型数据迁移中的技术观察:基于MongoDB协议兼容与安全治理的政务金融实践
  • 为什么ResNet-50能解决梯度消失?深入图解残差连接原理
  • B样条vs贝塞尔:游戏角色动画该选哪种曲线?Unity性能实测对比
  • 避坑指南:多组学相关性热图绘制常见的5个数据预处理错误及解决方法
  • AI4S重塑药物研发:药物研发中的AI应用,外包还是自主掌握?
  • DAMOYOLO-S模型鲁棒性测试:对抗样本攻击与防御初探
  • 即席查询框架选型指南:从Presto到ClickHouse的7种方案对比(2023版)
  • AI小程序定制开发:河南企业如何选择靠谱的技术服务商?
  • Cogito-V1-Preview-Llama-3B辅助C语言学习:代码注释生成与基础概念讲解
  • 轻资产创业实战:KISSABC 智能化云仓与数字化系统如何赋能合作伙伴稳健经营?
  • 书匠策AI:文献综述的“智能建筑师”,搭建学术研究的稳固基石
  • MySQL 最左前缀,一篇讲明白,面试实战都能用
  • 谷歌浏览器自动刷新插件安装与使用指南
  • Glyph视觉推理模型从零开始:部署、使用与优化全攻略
  • 国内AI开发者必备:HuggingFace镜像站hf-mirror.com的4种高效下载方法(附避坑指南)
  • 轨迹跟踪,考虑侧倾和曲率变化,同时修正侧偏刚度 simulink carsim联合仿真
  • 金仓数据库在银行存取记录系统MySQL迁移中的实践总结:零停机切换与性能优化复盘
  • 0基础自学大模型6个月,6个offer,大模型面试复盘:从0基础到拿到Offer,我的转行避坑指南!
  • OBS多平台直播神器:obs-multi-rtmp插件3分钟快速上手指南
  • 如何精准评估鼠标性能?专业测试工具全攻略
  • Python+AKShare实战:5分钟搭建LOF基金溢价监控系统(附微信推送配置)