SpringCloud-Netflix学习笔记10——Hystrix实现服务熔断
创始人
2024-05-23 22:27:09
0

一、概述

1、分布式系统面临的问题

复杂分布式体系结构中的应用程序有数十个依赖关系,每个依赖关系在某些时候将不可避免的失败!
在这里插入图片描述

2、服务雪崩

多个微服务之间调用的时候,假设微服务A调用微服务B和微服务C,微服务B 和微服务C又调用其他的微服务,这就是所谓的 “扇出”、如果扇出的链路上某个微服务的调用响应时间过长或者不可用,对微服务A的调用就会占用越来越多的系统资源,进而引起系统崩溃,所谓的 “雪崩效应”。

对于高流量的应用来说,单一的后端依赖可能会导致所有服务器上的所有资源都在几秒中内饱和。比失败更糟糕的是,这些应用程序还可能导致服务之间的延迟增加,备份队列,线程和其他系统资源紧张,导致整个系统发生更多的级联故障,这些都表示需要对故障和延迟进行隔离和管理,以便单个依赖关系的失败,不能取消整个应用程序或系统。

我们需要 ·弃车保帅·

3、什么是Hystrix

Hystrix是一个用于处理分布式系统的延迟和容错的开源库,在分布式系统里,许多依赖不可避免的会调用失败,比如超时,异常等,Hystrix能够保证在一个依赖出问题的情况下,不会导致整体服务失败,避免级联故障,以提高分布式系统的弹性。

“断路器” 本身是一种开关装置,当某个服务单元发生故障之后,通过断路器的故障监控(类似熔断保险丝),向调用方返回一个服务预期的,可处理的备选响应(FallBack),而不是长时间的等待或者抛出调用方法无法处理的异常,这样就可以保证了服务调用方的线程不会被长时间,不必要的占用,从而避免了故障在分布式系统中的蔓延,乃至雪崩。

4、Hystrix能干嘛

  • 服务熔断
  • 服务降级
  • 服务限流
  • 接近实时的监控
  • … …

5、官网资料

https://github.com/Netflix/Hystrix/wiki

二、服务熔断

1、是什么?

熔断机制是对应雪崩效应的一种微服务链路保护机制。

当扇出链路的某个微服务不可用或者响应时间太长时,会进行服务的降级,进而熔断该节点微服务的调用,快速返回 错误的响应信息。当检测到该节点微服务调用响应正常后恢复调用链路。在SpringCloud框架里熔断机制通过Hystrix实现。Hystrix会监控微服务间调用的状况,当失败的调用到一定阈值,缺省是5秒内20次调用失败就会启动熔断机制。下面我们画个图来进行理解:

微服务之间肯定存在互相调用的关系,如下图,用户请求进入服务,调用服务A,服务A调用服务B,服务B调用服务C,服务C调用服务D,最后服务D响应给回用户,一次请求结束:
在这里插入图片描述
此时如果服务B宕机了,用不了了,那么这个调用链路就会发生故障,服务A一直等待去调用服务B,因为链路到不了服务D,不能响应给回用户,所以这次请求一直未结束,一直占用系统资源,严重的话可能会引起整个系统的故障:
在这里插入图片描述
我们服务熔断的含义就是,当服务B发生故障时,我们将服务A对服务B的调用过程给断掉,我们一开始就设置一个备选服务,当服务B发生故障时,我们可以去调用备选服务,给回用户响应,已结束本次请求:

当然,这个备选服务可以有两种选择:

  1. 备选服务的功能和服务B一样,可以正常执行调用服务C的流程,最后返回正确的响应信息。
  2. 备选服务直接返回错误信息,提醒用户本次请求发生错误。

在这里插入图片描述

熔断机制的注解是 @HystrixCommand

我们下面的例子以方式二来说明。

三、实例

1、拷贝一份 springcloud-provider-dept-8001 命名为 springcloud-provider-dept-hystrix-8001
2、添加 Hystrix的依赖:

        org.springframework.cloudspring-cloud-starter-hystrix1.4.7.RELEASE

3、在可能发生错误的服务上添加一个注解 @HystrixCommand(fallbackMethod = "备选服务名(或函数名)")

4、编写备选服务,Controller 代码如下:

/提供Restful 服务
@RestController
@RequestMapping("/dept")
public class DeptController {@Autowiredprivate DeptService deptService;@GetMapping("/queryDeptById/{id}")// 如果这个方法调用失败,就会执行熔断备选方法queryDeptByIdHystrix@HystrixCommand(fallbackMethod = "queryDeptByIdHystrix")public Dept queryDeptById(@PathVariable("id") Long id){Dept dept = deptService.queryDeptById(id);if(dept == null){throw new RuntimeException("id=>" + id + "不存在该用户,或者信息无法找到!");}return dept;}// 熔断版的备选方案public Dept queryDeptByIdHystrix(@PathVariable("id") Long id){return new Dept().setDeptno(id).setDname("id=>" + id + "没有对应的信息,null--@Hystrix!").setDbSource("no this database in Mysql");}}

5、在主启动类上开启服务熔断,添加一个注解即可:

@EnableCircuitBreaker  //添加对Hystrix熔断的支持

接下来开启服务以及集群,就可以看到效果了!当服务发生错误时,会去执行备选服务,返回错误信息给用户!

相关内容

热门资讯

新年主持词开场白 2021新年主持词开场白(精选5篇)  主持词没有固定的格式,他的最大特点就是富有个性。在人们越来越...
龙舟节活动致辞 龙舟节活动致辞  在平日的学习、工作和生活里,大家都对致辞很是熟悉吧,致辞是指在仪式上所讲的表示勉励...
新闻发布会主持词 新闻发布会主持词  主持词没有固定的格式,他的最大特点就是富有个性。随着社会一步步向前发展,主持词在...
“庆元旦”文艺汇演园长致辞 “庆元旦”文艺汇演园长致辞尊敬的各位家长,亲爱的小朋友们:大家下午好!又是一年人增岁,转瞬间2012...
婚礼的致辞 婚礼的致辞(精选15篇)  在学习、工作乃至生活中,要用到致辞的地方还是很多的,致辞是指在仪式上所讲...
教师节表彰会主持词 教师节表彰会主持词  沐浴着送爽的浩荡金风,品味着收获的温馨喜悦,又迎来一个新的教师节,下面是小编整...
公司年会致辞 公司年会致辞(15篇)  在现实生活或工作学习中,大家都不可避免地要接触到致辞吧,致辞具有很强的实用...
签约仪式主持词 签约仪式主持词  签约是一件非常严肃的事,也可能是你人生中最重要的一件事,所以,请大家一定要认真对待...
年终晚会主持词 年终晚会主持词范文集锦五篇  主持词是主持人在节目进行过程中用于串联节目的串联词。我们眼下的社会,主...
建筑理事会闭幕讲话 建筑理事会闭幕讲话  欢迎来到CN人才网,下面是小编精心为大家整理的建筑理事会闭幕讲话,希望对大家有...
新郎父亲在婚礼上的致辞 新郎父亲在婚礼上的致辞各位领导,各位亲朋好友,两位亲家:  上午好!今天,在儿子新婚之喜的时刻,借助...
通用主持词 通用主持词十篇  主持词要注意活动对象,针对活动对象写相应的主持词。在当今中国社会,主持词与我们不再...
首届文化节闭幕式主持词 首届文化节闭幕式主持词  活动对象的不同,主持词的写作风格也会大不一样。在一步步向前发展的社会中,各...
启动仪式主持词 启动仪式主持词(精选12篇)  由主持人于节目进行过程中串联节目的串联词。如今的各种演出活动和集会中...
员工大会主持词结束语分享 员工大会主持词结束语分享  一、 整理队形  徐:请各部门赶快入场,按指示牌站整齐。  二、 准备开...
班级毕业晚会主持词 班级2021年毕业晚会主持词  主持人在台上表演的灵魂就表现在主持词中。在当下的中国社会,司仪等是很...
白事主持词 白事主持词  主持词没有固定的格式,他的最大特点就是富有个性。在各种集会、活动不断增多的社会,主持成...
领导证婚人婚礼精彩致辞 领导证婚人婚礼精彩致辞(通用13篇)  在平平淡淡的学习、工作、生活中,大家都不可避免地要接触到致辞...
儿童节主持词 儿童节主持词(精选15篇)  主持人在台上表演的灵魂就表现在主持词中。现今社会在不断向前发展,主持人...