SpringCloudAlibaba中使用Sentinel实现流量控制以及流控规则详解:
SpringCloudAlibaba中使用Sentinel实现流量控制以及流控规则详解_霸道流氓气质的博客-程序员宅基地
在上面使用Sentinel实现流量控制的基础上,怎样进行熔断降级。
https://github.com/alibaba/Sentinel/wiki/%E7%86%94%E6%96%AD%E9%99%8D%E7%BA%A7
除了流量控制以外,对调用链路中不稳定的资源进行熔断降级也是保障高可用的重要措施之一。一个服务常常会调用别的模块,可能是另外的一个远程服务、数据库,或者第三方 API 等。例如,支付的时候,可能需要远程调用银联提供的 API;查询某个商品的价格,可能需要进行数据库查询。然而,这个被依赖服务的稳定性是不能保证的。如果依赖的服务出现了不稳定的情况,请求的响应时间变长,那么调用服务的方法的响应时间也会变长,线程会产生堆积,最终可能耗尽业务自身的线程池,服务本身也变得不可用。
现代微服务架构都是分布式的,由非常多的服务组成。不同服务之间相互调用,组成复杂的调用链路。以上的问题在链路调用中会产生放大的效果。复杂链路上的某一环不稳定,就可能会层层级联,最终导致整个链路都不可用。因此我们需要对不稳定的弱依赖服务调用进行熔断降级,暂时切断不稳定调用,避免局部不稳定因素导致整体的雪崩。熔断降级作为保护自身的手段,通常在客户端(调用端)进行配置。
注意官方版本说明,此时的版本为1.8.4
1、慢调用比例 (SLOW_REQUEST_RATIO):
选择以慢调用比例作为阈值,需要设置允许的慢调用 RT(即最大的响应时间),请求的响应时间大于该值则统计为慢调用。当单位统计时长(statIntervalMs)内请求数目大于设置的最小请求数目,并且慢调用的比例大于阈值,则接下来的熔断时长内请求会自动被熔断。经过熔断时长后熔断器会进入探测恢复状态(HALF-OPEN 状态),若接下来的一个请求响应时间小于设置的慢调用 RT 则结束熔断,若大于设置的慢调用 RT 则会再次被熔断。
2、异常比例 (ERROR_RATIO):
当单位统计时长(statIntervalMs)内请求数目大于设置的最小请求数目,并且异常的比例大于阈值,则接下来的熔断时长内请求会自动被熔断。经过熔断时长后熔断器会进入探测恢复状态(HALF-OPEN 状态),若接下来的一个请求成功完成(没有错误)则结束熔断,否则会再次被熔断。异常比率的阈值范围是 [0.0, 1.0],代表 0% - 100%。
3、异常数 (ERROR_COUNT):
当单位统计时长内的异常数目超过阈值之后会自动进行熔断。经过熔断时长后熔断器会进入探测恢复状态(HALF-OPEN 状态),若接下来的一个请求成功完成(没有错误)则结束熔断,否则会再次被熔断。
SpringCloud中集成Hystrix实现服务降级(从实例入手):
SpringCloud中集成Hystrix实现服务降级(从实例入手)_霸道流氓气质的博客-程序员宅基地
SpringCloud中集成Hystrix实现熔断(从实例入手):
SpringCloud中集成Hystrix实现熔断(从实例入手)_霸道流氓气质的博客-程序员宅基地
注:
博客:
霸道流氓气质的博客_程序员宅基地-C#,架构之路,SpringBoot领域博主
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。
1、熔断策略-慢调用比例
参考上面集成Sentinel实现流量控制的基础上,添加测试接口
@GetMapping("/testD")
public String testD()
{
try { TimeUnit.SECONDS.sleep(1); } catch (InterruptedException e) { e.printStackTrace(); }
log.info("testD 测试RT");
return "------testD";
}
使接口等待一秒之后返回。
然后新建熔断规则,配置参数如下
熔断降级规则(DegradeRule)包含下面几个重要的属性:
Field 说明 默认值
resource 资源名,即规则的作用对象
grade 熔断策略,支持慢调用比例/异常比例/异常数策略 慢调用比例
count 慢调用比例模式下为慢调用临界 RT(超出该值计为慢调用);异常比例/异常数模式下为对应的阈值
timeWindow 熔断时长,单位为 s
minRequestAmount 熔断触发的最小请求数,请求数小于该值时即使异常比率超出阈值也不会熔断(1.7.0 引入) 5
statIntervalMs 统计时长(单位为 ms),如 60*1000 代表分钟级(1.8.0 引入) 1000 ms
slowRatioThreshold 慢调用比例阈值,仅慢调用比例模式有效(1.8.0 引入)
熔断器事件监听
具体可以参考其官网
所以这里配置的规则的含义是:
如果一秒内持续进入大于等于5个请求,并且请求响应的时间大于200毫秒的请求即为慢调用,当慢调用的比例大于0.2时就会触发降级,直到3秒后新的请求响应时间小于200毫秒才结束熔断。
使用jmeter进行压力模拟测试可以参考如下
Jmeter进行http接口压力测试:
Jmeter进行http接口压力测试_霸道流氓气质的博客-程序员宅基地
这里模拟10个线程一秒一次的发起请求并持续进行。
启动jmeter压力测试之后再访问testD接口
2、熔断策略-异常比例
修改上面的testD接口,让其出现异常
@GetMapping("/testD")
public String testD()
{
log.info("testD 异常比例");
int age = 10/0;
return "------testD";
}
此时直接访问该接口,没有触发熔断降级之前会直接报错
修改上面的熔断策略如下
此规则的含义为:
如果1秒内持续进入大于等于5个请求,并且请求中异常的比例大于0.2,则触发降级,降级时间持续3秒,3秒后,如果不再异常,才结束熔断。
效果
3、熔断降级策略-异常数
修改上面的规则如下
上面配置的含义是:
如果1秒内持续进入大于等于5个请求,并且请求发生异常数超过4时,会触发熔断降级持续2秒。
效果
文章浏览阅读5.7k次。模拟浏览器请求的插件,本人使用的是火狐的HttpRequester插件,安装方法是在扩展程序中搜索名称添加,重启浏览器即可 本文是记录Post和Get请求的基本方法1、Post请求带参数 如上图,若选择请求内容为json格式,则必须使用json(键值对)格式的内容,否则请求报错,请求内容格式如下:{"kkk":{"name":"ddd","age":111},"ssss":{"name":_httprequester 火狐
文章浏览阅读864次。git22端口不可用 换端口_github ssh 22 time out
文章浏览阅读4.4k次,点赞3次,收藏21次。让AI帮你玩游戏让AI帮你玩游戏(二)训练模型并获取结果 训练模型 用训练好的Model获取坐标 实现我们想要的功能 最后再次声明:本文所涉及的内容仅用作学习研究,严禁用于非法用途,游戏中违反相关协议可能会使你失去你的游戏账号! 教程完结,祝大家生活愉快! 书接上文:我们在上一期介绍了我们整体的思路以及创建训练数据,搭建ssd-resnet50模型,现在我们开始训练我们的模型,并用我们训练好的模型获得浮标所在的坐标。让AI帮你玩游戏(二)训练模型并获取结果训练模型._用ai训练玩游戏
文章浏览阅读1w次。无忧主机小编今天帮一个要好的香港虚拟空间站长哥们建一个论坛站点。域名解析到主机上。什么都配置好了,小编开始一如既往的开始往虚拟主机空间上传论坛程序了。网速很给力,5分钟就安装搞定了这个熟悉的不能再熟悉的Discuz论坛程序了。小编高高高兴的开始去交差了。可是没想到他又让小编帮忙配置下ucenter.反正这个小编都配置了很多遍了。就爽快的答应了。什么都配置好了。小编准备测试下,就可以交差完事了。可是_dz论坛验证码不显示关闭登录验证码
文章浏览阅读934次,点赞21次,收藏20次。论文:DiffAttack: Evasion Attacks Against Diffusion-Based Adversarial Purification。_diffattack: evasion attacks against diffusion-based adversarial purification
文章浏览阅读71次。摘要:Background: EarlyR is a prognostic gene signature score in ER+ breast cancer (BC) computed from the expression values of ESPL1, SPAG5, MKI67, PLK1 and PGR using a novel algorithm. EarlyR has been v..._earlyr risk group
文章浏览阅读343次。本文纯属无聊写下这是个生成器numbers = (i for i in range(100))这也是个生成器def numbers():for i in range(100):yield i他们两者本质是一码事,前者是后者的语法糖而已。那这是啥?numbers = [i for i in range(100)]其实本质上是这numbers = list((i for i in range(100)..._generator send
文章浏览阅读108次。Fail2ban的filter在FreeSWITCH1.10.7失效_/etc/fail2ban/filter.d/freeswitch.conf 1.10.7
文章浏览阅读2.7k次。ethtool 读到的链接状态使用 ethtool 读取网卡链接状态的一个示例如下:longyu@longyu-pc:~$ sudo /sbin/ethtool ens37 [sudo] password for longyu: Settings for ens37: Supported ports: [ TP ] Supported link modes: 10baseT/Hal..._ethtool_ops
文章浏览阅读5.1k次,点赞4次,收藏13次。这种情况,很可能是其它系统响应速度慢造成。接口中如果涉及外对象,一定要在日志中记录好1)请求地址;4)发起请求前后的时间(日志框架会在记录请求和响应报文时,自动记录时间)这种情况比较少,一般对大对象进行排序、多重循环等操作容易造成明显的速度下降。代码中如果有双重或多重循环,开发人员应引起足够重视。sql查询语句如果涉及的表数据量比较大,或者关联表较多,比较复杂,都需特别注重性能测试。当时把sql摘出来在数据库工具中执行秒出,上了生产环境后要1分半。尽量避免在代码中循环调用sql。_java接口响应慢的解决思路
文章浏览阅读9.1k次。OracleEnterpriseManager(Oracle企业管理器,简称OEM)是通过一组Oracle程序,为管理分布式环境提供了管理服务。OEM包括了一组DBA工具,一个repository,以及一个图形化显示的控制台。OEM控制台与每一个服务器上的智能化**(IntelligentAgent)相对应。 智能化**能够监控系统的特定事件并且执行任务(作业)就象你在系统本地一样。事件和作业的_oemm oracle
文章浏览阅读357次,点赞3次,收藏7次。随着血液的流通,移植的猪肾开始呈现健康的粉红色,并履行其功能,产生尿液。这一成功的瞬间,手术室内的15名移植专家目睹了这一令人赞叹的景象,并在周四的新闻发布会上由Kawai博士宣布了这一喜讯,他们以热烈的掌声庆祝了这一成就,这不仅标志着手术的胜利完成,也展示了医学领域在治疗重大疾病上取得的重大进展。在麻省总医院,一支专业的医疗团队正在进行一项关键的手术操作:将一颗经过多次基因编辑的猪肾逐步植入病人Slayman的循环系统内,这一过程由于患者自身存在的疾病而显得尤为复杂,因为其血管条件并不理想。