流控神器Sentinel指南:浅析Sentinel中的抽象概念

2024-03-28 15:38

本文主要是介绍流控神器Sentinel指南:浅析Sentinel中的抽象概念,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上篇文章中介绍了Sentinel的一些使用方式,从这篇文章开始叙述Sentinel的一些高级用法和底层的实现原理。

1. Sentinel中的抽象概念

解读源码之前我们需要认识Sentinel中的抽象概念。比较重要的概念为:Resource、Entry、Solt、Rule、context、Node、Metric等

下面我们一一分析

2 Resource

资源可以是任何东西,比如一段代码,一个方法。通常用以NAME来区分别的资源。在sentinel中具体表示资源的类是:ResourceWrapper类图如下:

sentinel

ResourceWrapper 有两个属性,name标识了唯一性,而entryType标识该资源被访问的类型。
即标识资源是入站或出站方法。 这用于标记在系统不稳定时是否可以阻止它,SystemRule只可以阻止入站流量。

它有两个实现类,分别是:StringResourceWrapperMethodResourceWrapper,前者和ResourceWrapper基本没区别,后者稍微有点不同,它多一个Method
字段,它其实表示对一个方法资源的包装。我们看一下的它的构造方法就明白了:

public MethodResourceWrapper(Method method, EntryType type) {this.method = method;// 通过反射获取到一个方法的唯一名称,重载/重写的的方法获取的结果不同this.name = MethodUtil.getMethodName(method);this.type = type;
}
3. Entry

代表一次对资源的访问,每访问一个资源都会创建一个Entry。每次执行 SphU.entry()都会返回一个Entry给调用者。如果发生限流抛出BlockExcetion,SphO.entry()的返回值是true/flase。
Entry的类图如下:

sentinel

Eentry中保存了本次执行访问资源的一些基本信息,包括:

  • createTime:当前Entry的创建时间,主要用来后期计算rt
  • curNode:当前Entry所关联的node,该node主要是记录了当前context下该资源的统计信息
  • originNode:当前Entry的调用来源,通常是调用方的应用名称,在ClusterBuilderSlot.entry()方法中设置的
  • resourceWrapper:当前Entry访问的资源

当在一个上下文中多次调用了SphU.entry()方法时,就会创建一棵树,节点之间是通过parent和child关系维持的。

前面所说的一个上下文指比较抽象,看下面代码:

ContextUtil.enter("entrance1", "appA");Entry entry = SphU.entry("resource1");if (entry != null) {entry.exit();}ContextUtil.exit();

ContextUtil.enter() 创建了一个名为 entrance1 的上下文,同时指定调用发起者为 appA;接着通过 SphU.entry()请求资源。代码将在内存中生成以下结构:

     machine-root//EntranceNode1()//DefaultNode(entry)
4. Context

上一小节提到了上下文。Context即上下文,一个上下文只能通过两种方式创建,一是暴露出来的ContextUtil.enter() 方式,而是内部ContextUtil的一个子类创建,这是默认的内部创建方式,为一次访问资源创建上下文。Context是保存在ThradLocal中。可以把Conetext理解当一次访问资源的过程。Context中维护着当前调用链的元数据。属性如下:

    // Context nameprivate final String name;// 当前调用链的入口节点,即最外层的entryprivate DefaultNode entranceNode;// 调用链的当前节点private Entry curEntry;// 当前调用链的调用源private String origin = "";
5. Node

node中保存了资源的实时统计数据,如:passQps,blockQps,rt等实时数据。正是有了这些统计数据后,sentinel才能进行限流、降级等一系列的操作。

sentinel

entranceNode是每个上下文的入口,该节点是直接挂在root下的,是全局唯一的,跟entry没有关系,内部自动生成的。每一个context都会对应一个entranceNode,当然多个context可能对应一个相同的entranceNode。如果没有使用ContextUtil.enter("entrancexxx", "appA");,则context会指向默认的第一个entranceNode。

defaultNode是记录某一个资源调用的实时数据的,entry的curNode指向一个defaultNode。一个资源可能有被多个defaultNode关联。每个defaultNode都关联着一个资源和clusterNode,有着相同资源的defaultNode关联着同一个clusterNode。
关系图如下:
sentienl

6. Slot

slot为“插槽”的意思,显然它会有多个,Sentinel中的功能是通过每一个插槽来实现的。槽对应的接口为ProcessorSlot,多个槽通过链表来连接。这个链表称为ProcessorSlotChain。
槽的多个实现有,摘一段初始化代码:

public class DefaultSlotChainBuilder implements SlotChainBuilder {@Overridepublic ProcessorSlotChain build() {ProcessorSlotChain chain = new DefaultProcessorSlotChain();chain.addLast(new NodeSelectorSlot());chain.addLast(new ClusterBuilderSlot());chain.addLast(new LogSlot());chain.addLast(new StatisticSlot());chain.addLast(new SystemSlot());chain.addLast(new AuthoritySlot());chain.addLast(new FlowSlot());chain.addLast(new DegradeSlot());return chain;}
}

Sentinel内部帮我们已经添加好了,并且顺序固定。这些插槽有不同的职责:

  • NodeSelectorSlot 负责收集资源的路径,并将这些资源的调用路径,以树状结构存储起来,用于根据调用路径来限流降级;
  • ClusterBuilderSlot 则用于存储资源的统计信息以及调用者信息,例如该资源的 RT, QPS, thread count 等等,这些信息将用作为多维度限流,降级的依据;
  • StatisticSlot 则用于记录、统计不同纬度的 runtime 指标监控信息;
  • FlowSlot 则用于根据预设的限流规则以及前面 slot 统计的状态,来进行流量控制;
  • AuthoritySlot 则根据配置的黑白名单和调用来源信息,来做黑白名单控制;
  • DegradeSlot 则通过统计信息以及预设的规则,来做熔断降级;
  • SystemSlot 则通过系统的状态,例如 load1 等,来控制总的入口流量;
7. Metric

metric是sentinel中用来进行实时数据统计的度量接口,node就是通过metric来进行数据统计的。

8. Rule

Sentinel有流量控制规则、熔断降级规则、系统保护规则 以及授权规则。类图如下:
sentinel
每种规则都有对应的管理工具类,比如DegradeRuleManager.loadRules(rules)将降级规则加载到内存。

Sentinel中相对抽象的概念基本就是以上这些,这些基本知识对深入解读底层原理至关重要。

这篇关于流控神器Sentinel指南:浅析Sentinel中的抽象概念的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/856011

相关文章

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了

Java 创建图形用户界面(GUI)入门指南(Swing库 JFrame 类)概述

概述 基本概念 Java Swing 的架构 Java Swing 是一个为 Java 设计的 GUI 工具包,是 JAVA 基础类的一部分,基于 Java AWT 构建,提供了一系列轻量级、可定制的图形用户界面(GUI)组件。 与 AWT 相比,Swing 提供了许多比 AWT 更好的屏幕显示元素,更加灵活和可定制,具有更好的跨平台性能。 组件和容器 Java Swing 提供了许多

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(五):Blender锥桶建模

前言 本系列教程旨在使用UE5配置一个具备激光雷达+深度摄像机的仿真小车,并使用通过跨平台的方式进行ROS2和UE5仿真的通讯,达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础,Nav2相关的学习教程可以参考本人的其他博客Nav2代价地图实现和原理–Nav2源码解读之CostMap2D(上)-CSDN博客往期教程: 第一期:基于UE5和ROS2的激光雷达+深度RG

Sentinel 高可用流量管理框架

Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 Sentinel 具有以下特性: 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应

如何掌握面向对象编程的四大特性、Lambda 表达式及 I/O 流:全面指南

这里写目录标题 OOP语言的四大特性lambda输入/输出流(I/O流) OOP语言的四大特性 面向对象编程(OOP)是一种编程范式,它通过使用“对象”来组织代码。OOP 的四大特性是封装、继承、多态和抽象。这些特性帮助程序员更好地管理复杂的代码,使程序更易于理解和维护。 类-》实体的抽象类型 实体(属性,行为) -》 ADT(abstract data type) 属性-》成

(入门篇)JavaScript 网页设计案例浅析-简单的交互式图片轮播

网页设计已经成为了每个前端开发者的必备技能,而 JavaScript 作为前端三大基础之一,更是为网页赋予了互动性和动态效果。本篇文章将通过一个简单的 JavaScript 案例,带你了解网页设计中的一些常见技巧和技术原理。今天就说一说一个常见的图片轮播效果。相信大家在各类电商网站、个人博客或者展示页面中,都看到过这种轮播图。它的核心功能是展示多张图片,并且用户可以通过点击按钮,左右切换图片。

使用条件变量实现线程同步:C++实战指南

使用条件变量实现线程同步:C++实战指南 在多线程编程中,线程同步是确保程序正确性和稳定性的关键。条件变量(condition variable)是一种强大的同步原语,用于在线程之间进行协调,避免数据竞争和死锁。本文将详细介绍如何在C++中使用条件变量实现线程同步,并提供完整的代码示例和详细的解释。 什么是条件变量? 条件变量是一种同步机制,允许线程在某个条件满足之前进入等待状态,并在条件满

以后写代码都是AI自动写了,Cursor+Claude-3.5-Sonnet,Karpathy 点赞的 AI 代码神器。如何使用详细教程

Cursor 情况简介 AI 大神 Andrej Karpathy 都被震惊了!他最近在试用 VS Code Cursor +Claude Sonnet 3.5,结果发现这玩意儿比 GitHub Copilot 还好用! Cursor 在短短时间内迅速成为程序员群体的顶流神器,其背后的原因在于其默认使用 OpenAI 投资的 Claude-3.5-Sonnet 模型,这一举动不仅改变了代码生成

OBItools:Linux下的DNA条形码分析神器

在生物信息学领域,DNA条形码分析是一种非常常见的研究方法,用于物种鉴定、生态学和进化生物学研究。今天要介绍的工具就是专为此设计的——OBItools。这个工具集专门用于处理生态学和进化生物学中的DNA条形码数据,在Linux环境下运行。无论你是本科生还是刚入门的科研人员,OBItools都能为你提供可靠的帮助。 OBItools的功能亮点 OBItools是一个强大的工具包,特别适合DNA条形