范文健康探索娱乐情感热点
投稿投诉
热点动态
科技财经
情感日志
励志美文
娱乐时尚
游戏搞笑
探索旅游
历史星座
健康养生
美丽育儿
范文作文
教案论文

Sentinel是如何实现分布式限流的?

  随着近些年系统稳定性要求越来越高,限流是保障服务高可用的方式之一,尤其是在微服务架构中,对接口或资源进行限流可以有效地保障服务的可用性和稳定性。
  在众多限流平台中 Sentinel 凭着丰富功能特性和多次阿里双十一的线上实践,成为最热门限流平台之一,Sentinel 是阿里巴巴提供的一种限流、熔断中间件,与RateLimiter相比,Sentinel提供了丰富的限流、熔断功能。它支持控制台配置限流、熔断规则,支持集群限流,并可以将相应服务调用情况可视化。
  本文就Sentinel相关特性进行分析并测试并对底层原理进行分析,为后续相关系统建设积累经验。一、总体流程
  之前我们学习过限流比较主流的三种算法:漏桶,令牌桶,滑动窗口。而Sentinel采用的是最后一种,滑动窗口来实现限流的。
  先来了解一下总体流程:
  上面的图是官网的图,从设计模式上来看,典型的的责任链模式。外部请求进来后,要经过责任链上各个节点的处理,而Sentinel的限流、熔断就是通过责任链上的这些节点实现的。
  要想深入了解原理,还是得从源码上入手,下面直接进入Sentinel的源码阅读。二、源码阅读
  2.1源码阅读入口及流程总结
  读源码先得找到源码入口。我们经常使用@ SentinelResource来标记一个方法,可以将这个被@ SentinelResource标记的方法看成是一个Sentinel资源。因此,我们以@ SentinelResource为入口,找到其切面,看看切面拦截后所做的工作,就可以明确Sentinel的工作原理了。直接看注解@SentinelResource的切面代码(SentinelResourceAspect)。
  可以清晰的看到Sentinel的行为方式。进入SentinelResource切面后,会执行SphU.entry方法,在这个方法中会对被拦截方法做限流和熔断的逻辑处理。
  如果触发熔断和限流,会抛出BlockException,我们可以指定blockHandler方法来处理BlockException。而对于业务上的异常,我们也可以配置fallback方法来处理被拦截方法调用产生的异常。
  所以,Sentinel熔断限流的处理主要是在SphU.entry方法中,其主要处理逻辑见下图源码。
  可见,在SphU.entry方法中,Sentinel实现限流、熔断等功能的流程可以总结如下:获取Sentinel上下文(Context);获取资源对应的责任链;生成资源调用凭证(Entry);执行责任链中各个节点。2.2 责任链的执行
  再来看下面这张图,是不是很清晰了?
  NodeSelectorSlot用于获取资源对应的Node,并构建Node调用树,将SentinelSource的调用链路以Node Tree的形式组起来。ClusterBuilderSlot为当前Node创建对应的ClusterNode,聚合相同资源对应的不同Context的Node,后续的限流依据就是这个ClusterNode。
  ClusterNode继承自StatisticNode,记录着相应资源处理的一些统计数据。StatisticSlot用于更新资源调用的相关计数,用于后续的限流判断使用。FlowSlot根据资源对应Node的调用计数,判断是否进行限流。
  至此,Sentinel的责任链执行逻辑就完整了。三、原理总结
  通过对Sentinel源码的梳理,可以很清晰的理解Sentinel的限流过程,总结如下:三大组件Context、Entry、Node,是Sentinel的核心组件,各类信息及资源调用情况都由这三大类持有;采用责任链模式完成Sentinel的信息统计、熔断、限流等操作;责任链中NodeSelectSlot负责选择当前资源对应的Node,同时构建node调用树;责任链中ClusterBuilderSlot负责构建当前Node对应的ClusterNode,用于聚合同一资源对应不同Context的Node;责任链中的StatisticSlot用于统计当前资源的调用情况,更新Node与其对用的ClusterNode的各种统计数据;责任链中的FlowSlot根据当前Node对应的ClusterNode(默认)的统计信息进行限流;资源调用统计数据(例如PassQps)使用滑动时间窗口进行统计;所有工作执行完毕后,执行退出流程,补充一些统计数据,清理Context。
  作者:架构精进之路
  链接:https://juejin.cn/post/7198496671129813048

食蟹未必阳澄湖,全国大闸蟹平替吃货地图发布秋风起,蟹脚痒,又到金秋食蟹时。近日,天眼查发布全国大闸蟹平替吃货地图显示,全国有超6万家蟹相关企业。蟹企数量前十省份里,南方地区占了7省。除了江苏的蟹企数量以30。72占比一骑绝港珠澳大桥通车4周年出入境车辆超473万辆次港珠澳大桥(央广网记者官文清摄)央广网珠海10月25日消息(记者夏燕实习生徐秀秀)10月23日,港珠澳大桥迎来通车4周年。作为全国唯一一座同时连接港澳的24小时陆路口岸,4年来,港日媒丰田下调本财年全球产量据日本经济新闻网站10月24日报道,丰田21日发布消息称,预计本财年(截至2023年3月)其全球产量将低于原计划的970万辆。该公司之前曾预测本财年产量将达到历史最高水平,但目前因人生感悟心性,是一颗心在磨刀石上推来荡去,血淋淋的面容被粉饰以后,在筳席上给人看的光闪闪的面子。每一个夜晚,都是我们给自己画妆的时候皮肤的色泽和颜料的真假以及画功的深浅,都是决定次日舞台上不再过分沉溺于自己,改变人生不快乐的问题我一直想着这个问题人活着到底是为了什么。和大多数人的想法一样,活着就是为了幸福快乐。可是,我们要知道,能不痛苦就已经很幸运了。如果能感到幸福快乐,就是最幸运的事情了。动物只要不生病人生清醒语录人生之复杂,并不是短短几十年就能参透的。通透清醒的人很少,大部分人都会因为各种各样的原因,生活环境,以及生活压力等等而陷入混乱的情景之中。下面为大家呈现一些有关人生的语录,希望可以让人眼前一亮的暖心句子,句句蕴含人生哲理1这一生需要用钱捍卫尊严的地方实在太多了,请多点努力,少点矫情。2不敢奢望太多,只希望前面受的苦,能换来以后的平安顺遂。3每天给自己一个希望,试着用希望迎接朝霞,用笑声送走余晖,用活着,你只要明白并做到这三点,就可以活好并获得完美人生人是为活着本身而活,而不是为了活着之外的任何事物所活着。这是现代作家余华活着里的一句话,读来让人压抑唏嘘,感叹命运为何对主人公福贵如此不公,接二连三地将他身边的亲人一一夺去,最后只王治郅人生坎坷,离婚后与主持人再婚江山代有才人出,各领风骚数百年。随着时间的流逝,一代又一代曾经创造过传奇的球星们最终总会走向退役这个结局。在任的时候,他们都有同样的身份,而退役过后,每个人都拥有了不同的生活,曾经人生悲喜,唯有自渡人有悲欢离合,月有阴晴圆缺。生而为人,每个人都会有悲伤的时刻,也会有喜悦的时刻。人天生具有倾诉欲,无论悲或喜,都想与人分享,向人倾诉。但是,有时候倾诉欲太强未必是一件好事。你的悲伤杨绛先生活出人生至高境界我和谁都不争,和谁争我都不屑杨绛先生翻译的英国诗人兰德75岁时的诗作生与死,她说我和谁都不争,和谁争我都不屑。我爱大自然,其次就是艺术,我双手烤着生命之火取暖,火萎了,我也准备走了。这是杨绛先生最喜欢的一首诗