Sentinel源码阅读:整体架构设计

Sentinel框架构建调用关系树作为入口,利用滑动窗口收集数据,实现限流、熔断等功能。通过ProcessorSlot扩展点进行功能扩展。资源是 Sentinel 的关键概念,规则包括流量控制、熔断降级和系统保护。流量控制通过限制资源调用关系、运行指标和控制效果来保护服务器。熔断降级在资源响应时间变长或异常比例升高时启用,Sentinel通过并发线程数和响应时间进行控制。系统自适应保护防止雪崩,确保系统负载与入口流量平衡。
摘要由CSDN通过智能技术生成

Sentinel框架设计

Sentinel内部构建一个一个调用关系树做为入口,内部采用高性能滑动窗口实现来进行数据采集,同时将各种不同拦截功能构造成一个连接链组成了限流、熔断等核心功能。

Sentinel 将 ProcessorSlot 作为 SPI 接口进行扩展(1.7.2 版本以前 SlotChainBuilder 作为 SPI),使得 Slot Chain 具备了扩展的能力。您可以自行加入自定义的 slot 并编排 slot 间的顺序,从而可以给 Sentinel 添加自定义的功能。

Sentinel基本概念

资源

资源是 Sentinel 的关键概念。它可以是 Java 应用程序中的任何内容,例如,由应用程序提供的服务,或由应用程序调用的其它应用提供的服务,甚至可以是一段代码。在接下来的文档中,我们都会用资源来描述代码块。

只要通过 Sentinel API 定义的代码,就是资源,能够被 Sentinel 保护起来。大部分情况下,可以使用方法签名,URL,甚至服务名称作为资源名来标示资源。

 

规则

围绕资源的实时状态设定的规则,可以包括流量控制规则、熔断降级规则以及系统保护规则。所有规则可以动态实时调整。

 

Sentinel功能和设计理念

流量控制

什么是流量控制?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值