Sentinel全局默认熔断降级策略的思考

享学课堂特约作者:老顾

目录

前言

全局异常降级

熔断遗失

熔断降级

配置思考

总结

前言

之前的文章中老顾已经介绍了sentinel的基本用法,以及利用Sentinel-Dashboard控制台去配置降级策略,全局Feign调用默认异常,再可以通过nacos持久化方式保证降级策略不丢失。

整体在使用过程中,没有发现什么大问题;但是仔细看一下日志就会发现一些问题;且为了解决这个问题要配置很多东西。发现有个地方在使用的时候不方便;而且是很不方便,浪费很多时间。我们先看看使用过程中的问题

全局异常降级

在之前的文章中,老顾介绍了Feign调用异常全局降级策略,这里我们再简单描述一下


上图中表示有个普通的业务,consumer服务通过Feign调用provider服务,为了保证系统的稳定性,防止provider服务出现什么情况,在consumer服务配置了fallback降级策略

这样设置之后,即使provider服务挂了,我们也可以走fallback方法,可以获取到

Plain  Text===fall back===

这样就保证了整体系统的稳定,而不会因为provider服务不稳定导致consumer服务也不稳定,专业术语就是防止雪崩效应。

有没有发现Fegin接口中@FeignClient注解需加上fallback属性

Java@FeignClient(name = "service-provider",fallback = ProviderServiceFallback.class)

小伙伴们我们想一想,如果我们consumer有10个Feign的外部调用,也就是有10个Feign接口,那么要保证系统的稳定,我们需要在每个Feign接口上面配置fallback。而且一般降级逻辑业务处理都是很类似的,都是标准的业务。是不是很麻烦,那能不能系统有个全局的fallback处理呢?

之前的文章《Sentinel限流、降级的统一处理》中已经做过介绍,小伙伴可以出门右拐就可以找到。

本篇文章就不重复介绍具体的实现了。

熔断遗失

上面我们介绍了全局降级;我们来看看的效果,我们把provider服务关掉,这样直接访问consumer对象的getHeader方法,代码里面是先获得客户端传过来的header参数,再远程Feign调用方法。看如下代码

Plain  Texthttp://localhost:8083/getHeader

我们发现因为provider服务挂了,导致

Load balancer does not have available server for client: service-provider

不过我们的返回结果,还是友好的;保证系统照样进行

Java{

"statusCode": "0",

"statusMessage": "处理成功",

"data": "success"

}

我们再执行一次

Plain  Texthttp://localhost:8083/getHeader

照样报错!!!

不管执行几次,日志照样有异常;虽然前端看不出来!!!小伙伴有没有发现问题?怎么每次都有异常发生?现在的案例中的异常是provider服务不存在,大家看的不是太明显,因为consumer服务即时就知道立刻返回了异常;但如果异常是provider服务执行时间太长,导致consumer服务调用超时返回的异常;那么每次调用都产生超时异常,那根本起不到防止雪崩效应。

那是不是哪边出了问题了?对的,我们忘记配置Sentinel的降级策略了;本质就是熔断降级策略。

关于熔断,小伙伴们可以网上查看,补一下知识哦

熔断降级

之前文章中老顾介绍过Sentinel Dashboard,可以进行配置熔断降级;怎么安装,小伙伴们可以去看之前的文章

上面的配置代表,10秒内最小请求数达到2个,而且有1个异常就执行熔断,熔断持续10秒。

我们在执行多次,发现异常日志没有了。

这个原因就是

Plain  TextproviderServiceFeign.transferHeaders();

执行Fegin远程调用时,如果熔断了,执行此代码时不会执行远程调用;而是会立刻调用fallback方法。

这样配置后才算真正的配置完成,达到熔断后保护系统的稳定性。

配置思考

我们上面配置了一个熔断降级策略,资源名为

Plain  TextGET:http://service-provider/transferHeaders

这个是根据服务名+请求url组成的。如果我们有很多Feign的远程调用;如

如果有很多Feign接口,那是不是我们都要进行一一配置呢?都要到Sentinel Dashboard那边进行配置呢?

而且如果微服务很多,那对应的每个服务都要进行一一配置;有没有觉得很麻烦。而且配置熔断的规则都很类似,连数值很多都一样。

而且很多时候我们也不记得有多少Feign方法了,需要自己一看看查找,真的很麻烦

那能不能像全局降级fallback一样,有一个可以配置全局熔断策略的方法呢?这样我们就可以不需要配置,只要@FeignClient远程调用,都会默认自动配置上熔断降级策略。

小伙伴们想想有什么方案呢?老顾会在下一篇文章中介绍。

总结

有些知识确实需要在企业实战中发现问题,小伙伴们要善于观察、思考;重构解决方案,能不能找到更好的方案,从而提高效率,减少人为干预。小伙伴们持续看下一篇文章哦,介绍具体的实现方案哦。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容