什么是服务雪崩?

单个服务发生故障,占用过多的系统资源,从而导致级联故障的情况称为服务雪崩。

什么是Hystrix?

在分布式环境中,许多服务依赖项中的一些必然会失败。(服务挂了)

Hystrix是一个库,通过添加延迟容忍和容错逻辑,控制这些分布式服务之间的交互。

Hystrix通过隔离服务之间的访问点、停止级联失败和提供回退选项来实现这一点,所有这些都可以提高系统的整体弹性。

容错:允许犯错,在微服务开放中主要体现在服务故障。

简言之,Hystrix是一个实现容错机制的组件。【也是实现高可用的目的】

Hystrix的主要作用

  • 为网络请求设置超时
  • 使用断路器模式

什么是断路器模式?

家用空开就是一种断路器模式,前身是保险丝。假设某个电器负载过大而损坏,空开会跳闸,而保险丝会熔断。

假设没有空开或者保险丝呢?引起更大的电路故障,甚至导致火灾,再扩张可能会烧到邻居家的房子。

对于微服务来说同样如此,当某一个服务出现问题时,使用断路器关停服务,不会导致由于持续访问导致的资源占有从而引起其他服务的正常运行。

服务熔断与服务降级

服务熔断指的是当网络请求达到某一个阈值(可设置)时,为了防止服务过载,占用系统资源,暂停该服务的调用,使服务降级。【服务没挂,但是担心挂了,就让服务暂时休息一下】

服务降级涉及的范围更大,

  • 超时降级:主要配置好超时时间和超时重试次数和机制,并使用异步机制探测回复情况
  • 失败次数降级:主要是一些不稳定的api,当失败调用次数达到一定阀值自动降级,同样要使用异步机制探测回复情况
  • 故障降级:比如要调用的远程服务挂掉了(网络故障、DNS故障、http服务返回错误的状态码、rpc服务抛出异常),则可以直接降级。降级后的处理方案有:默认值(比如库存服务挂了,返回默认现货)、兜底数据(比如广告挂了,返回提前准备好的一些静态页面)、缓存(之前暂存的一些缓存数据)
  • 限流降级

    当我们去秒杀或者抢购一些限购商品时,此时可能会因为访问量太大而导致系统崩溃,此时开发者会使用限流来进行限制访问量,当达到限流阀值,后续请求会被降级;降级后的处理方案可以是:排队页面(将用户导流到排队页面等一会重试)、无货(直接告知用户没货了)、错误页(如活动太火爆了,稍后重试)。

如何理解服务熔断和服务降级的差异?

服务熔断的场景是请求次数过多而设计的一种保护策略。而服务降级是着眼于整个系统的各种问题(超时,故障等等)。服务熔断会引起服务降级。换句话说,熔断是降级的一部分。

@HystrixCommand注解

默认开启线程池隔离,服务熔断,服务降级

接着上次的工程做些修改:【和feign结合使用】

https://github.com/HCJ-shadow/Feign

  • 新建工程msc-consumer-hystrix-80

  • pom依赖
  1. <parent>
  2. <groupId>org.springframework.boot</groupId>
  3. <artifactId>spring-boot-starter-parent</artifactId>
  4. <version>2.1.7.RELEASE</version>
  5. <relativePath/> <!-- lookup parent from repository -->
  6. </parent>
  7. <properties>
  8. <java.version>1.8</java.version>
  9. <spring-cloud.version>Greenwich.SR2</spring-cloud.version>
  10. </properties>
  11. <dependencies>
  12. <dependency>
  13. <groupId>org.springframework.cloud</groupId>
  14. <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
  15. </dependency>
  16. <dependency>
  17. <groupId>org.springframework.boot</groupId>
  18. <artifactId>spring-boot-starter-test</artifactId>
  19. <scope>test</scope>
  20. </dependency>
  21. <dependency>
  22. <groupId>org.springframework.cloud</groupId>
  23. <artifactId>spring-cloud-starter-config</artifactId>
  24. </dependency>
  25. <!-- Eureka客户端启动需要依赖web模块-->
  26. <dependency>
  27. <groupId>org.springframework.boot</groupId>
  28. <artifactId>spring-boot-starter-web</artifactId>
  29. </dependency>
  30. <dependency>
  31. <groupId>org.springframework.cloud</groupId>
  32. <artifactId>spring-cloud-starter-openfeign</artifactId>
  33. </dependency>
  34. <dependency>
  35. <groupId>org.springframework.cloud</groupId>
  36. <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
  37. </dependency>
  38. <dependency>
  39. <groupId>org.springframework.cloud</groupId>
  40. <artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
  41. </dependency>
  42. <!-- <dependency>-->
  43. <!-- <groupId>org.springframework.cloud</groupId>-->
  44. <!-- <artifactId>spring-cloud-starter-openfeign</artifactId>-->
  45. <!-- </dependency>-->
  46. </dependencies>
  47. <dependencyManagement>
  48. <dependencies>
  49. <dependency>
  50. <groupId>org.springframework.cloud</groupId>
  51. <artifactId>spring-cloud-dependencies</artifactId>
  52. <version>${spring-cloud.version}</version>
  53. <type>pom</type>
  54. <scope>import</scope>
  55. </dependency>
  56. </dependencies>
  57. </dependencyManagement>
  58. <build>
  59. <plugins>
  60. <plugin>
  61. <groupId>org.springframework.boot</groupId>
  62. <artifactId>spring-boot-maven-plugin</artifactId>
  63. </plugin>
  64. </plugins>
  65. </build>
  • controller

    1. package zkrun.top.controller;
    2. import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
    3. import org.springframework.beans.factory.annotation.Autowired;
    4. import org.springframework.web.bind.annotation.RequestMapping;
    5. import org.springframework.web.bind.annotation.RequestMethod;
    6. import org.springframework.web.bind.annotation.RestController;
    7. import zkrun.top.service.Hystrix_FeignService;
    8. @RestController
    9. public class Hystrix_FeignController {
    10. @Autowired
    11. Hystrix_FeignService hystrix_feignService;
    12. @RequestMapping(value = "/feign/info/get",method = RequestMethod.GET)
    13. @HystrixCommand(fallbackMethod = "hystrix_fallback")
    14. public String request()
    15. {
    16. return this.hystrix_feignService.request();
    17. }
    18. public String hystrix_fallback()
    19. {
    20. return "当前服务故障,服务熔断已启动!";
    21. }
    22. }
  • application.yaml

  1. server:
  2. port: 80
  3. eureka:
  4. client:
  5. service-url:
  6. defaultZone: http://eureka6001.com:6001/eureka/,http://eureka6002.com:6002/eureka/,http://eureka6003.com:6003/eureka/
  7. spring:
  8. application:
  9. name: hystrix-consumer
  • 主启动类【@EnableCircuitBreaker】
  1. package zkrun.top;
  2. import org.springframework.boot.SpringApplication;
  3. import org.springframework.boot.autoconfigure.SpringBootApplication;
  4. import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
  5. import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
  6. import org.springframework.cloud.openfeign.EnableFeignClients;
  7. @SpringBootApplication
  8. @EnableFeignClients
  9. @EnableEurekaClient
  10. @EnableCircuitBreaker
  11. public class App_Consumer_Hystrix_Feign_80
  12. {
  13. public static void main(String[] args)
  14. {
  15. SpringApplication.run(App_Consumer_Hystrix_Feign_80.class, args);
  16. }
  17. }

运行测试:

  • 启动三个Eureka,
  • 启动5001,5002,5003
  • 启动hystrix80

测试服务熔断

使用Jmeter

http://jmeter.apache.org/download_jmeter.cgi

解压后双击bin下面的jmeter.bat即可

设置线程数为100

设置相关信息

执行测试,查看结果树

额嗯,完全抗的住啊!!!

设置线程数为500:

出现熔断情况。

测试服务降级

设置故障降级,把5001关停

调用降级方法,重复几次之后,将不再访问5001。【Ribbon的RetryRule策略】

假设重启服务,

即可正常访问。

小结:

  • 为了保持高可用,应用可以配置多份,这样即使故障一台,对外仍旧可以保持可用性。但是随之而来的是数据库的一致性问题。CAP理论的A与C只能选择一个也是这个原理。根据实际的业务情况,哪些业务是必须保持高可用的,而哪些是必须保持一致性的,需要进一步分析和判断。
  • Hystrix实现服务的熔断和降级策略的自由度很高,理解其原理,搭配Feign中集成的RIbbon访问算法,可以实现更高的扩展和组合。

代码参考:https://github.com/Noneplus/JavaDev-Note/tree/master/SpringCloud代码

熔断器Hystrix的更多相关文章

  1. spring cloud ----> RibbonClient设置的熔断器Hystrix不起作用

    Ribbon spring.io 官网的简介: Ribbon is a client side load balancer which gives you a lot of control over ...

  2. 微服务—熔断器Hystrix

    前言在微服务架构中,我们将系统拆分成了一个个的服务单元,各单元应用间通过服务注册与发现的方式互相依赖. 由于每个单元都在不同的进程中运行,依赖通过远程调用的方式执行,这样就有可能因为网络原因或是依赖服 ...

  3. 一起来学Spring Cloud | 第五章:熔断器 ( Hystrix)

    在微服务项目中,一个系统可以分割成很多个不同的服务模块,不同模块之间我们通常需要进行相互调用.springcloud中可以使用RestTemplate+Ribbon和Feign来调用(工作中基本都是使 ...

  4. 跟我学SpringCloud | 第四篇:熔断器Hystrix

    跟我学SpringCloud | 第四篇:熔断器Hystrix 1. 熔断器 服务雪崩 在正常的微服务架构体系下,一个业务很少有只需要调用一个服务就可以返回数据的情况,这种比较常见的是出现在demo中 ...

  5. spring cloud学习笔记四 熔断器Hystrix

    我们知道分布式服务有这样一个特点,每一个微服务都有自己的业务,并且很多时候一个微服务的业务要依赖于其他微服务,如果这些相互关联的微服务中其中某个微服务请求失败时,就会导致其他调用它的微服务也会请求失败 ...

  6. spring cloud微服务快速教程之(四)熔断器(Hystrix)及其工具(Dashboard、Turbine)

    0-为什么需要熔断器 在分布式系统中,各个服务相互调用相互依赖,如果某个服务挂了,很可能导致其他调用它的一连串服务也挂掉或者在不断等待中耗尽服务器资源,这种现象称之为雪崩效应: 未来防止系统雪崩,熔断 ...

  7. springcloud(四):熔断器Hystrix

    说起springcloud熔断让我想起了去年股市中的熔断,多次痛的领悟,随意实施的熔断对整个系统的影响是灾难性的,好了接下来我们还是说正事. 熔断器 雪崩效应 在微服务架构中通常会有多个服务层调用,基 ...

  8. SpringCloud(4)熔断器 Hystrix

    在微服务架构中,根据业务来拆分成一个个的服务,服务与服务之间可以相互调用(RPC),在Spring Cloud可以用RestTemplate+Ribbon和Feign来调用.为了保证其高可用,单个服务 ...

  9. SpringCloud学习笔记:熔断器Hystrix(5)

    1. Hystrix简介 在分布式系统中,服务与服务之间相互依赖,一种不可避免的情况是某些服务会出现故障,导致依赖于它们的其他服务出现远程调度的线程阻塞. Hystrix提供熔断器功能,能够阻止分布式 ...

  10. spring cloud(四)熔断器Hystrix

    熔断器 雪崩效应 在微服务架构中通常会有多个服务层调用,基础服务的故障可能会导致级联故障,进而造成整个系统不可用的情况,这种现象被称为服务雪崩效应.服务雪崩效应是一种因“服务提供者”的不可用导致“服务 ...

随机推荐

  1. 找到linux中当前java的安装位置

    先看java -version $java version "1.8.0_111" Java(TM) SE Runtime Environment (build 1.8.0_111 ...

  2. 个人永久性免费-Excel催化剂功能第67波-父子结构表转换添加辅助信息之子父关系篇

    Excel作为一款数据领域的万物互联工具,连接一切外部的多种多样的数据源.将数据带到Excel的环境中,再进行数据处理.转换.统计分析等工作,是众多表哥表姐们每天都在经历的事情.能最快速将其他来源数据 ...

  3. Excel催化剂开源第14波-VSTO开发之单元格区域转DataTable

    在Excel开发过程中,大部分时候是和Range单元格区域打交道,在VBA开发中,大家都知道的一点是,不能动不动就去遍历所有单元格,那性能是非常糟糕的,很多时候,是需要把整个单元格区域装入数组中再作处 ...

  4. C#3.0新增功能10 表达式树 07 翻译(转换)表达式

    连载目录    [已更新最新开发文章,点击查看详细] 本篇将介绍如何访问表达式树中的每个节点,同时生成该表达式树的已修改副本. 以下是在两个重要方案中将使用的技巧. 第一种是了解表达式树表示的算法,以 ...

  5. Python在office开发中的应用

    Python with Excel 有几个很好的Python模块能够方便地操作Excel的数据,包括读与写,不要求本地安装Excel.例如pandas, openpyxl, xlrd, xlutils ...

  6. 从零开始实现ASP.NET Core MVC的插件式开发(三) - 如何在运行时启用组件

    标题:从零开始实现ASP.NET Core MVC的插件式开发(三) - 如何在运行时启用组件 作者:Lamond Lu 地址:https://www.cnblogs.com/lwqlun/p/112 ...

  7. Apache SSI 远程命令执行漏洞复现

    Apache SSI 远程命令执行漏洞复现 一.漏洞描述 当目标服务器开启了SSI与CGI支持,我们就可以上传shtml,利用<!--#exec cmd=”id” -->语法执行命令. 使 ...

  8. web设计_5_自由的框式组件

    1. CSS3 border-radius 圆角矩形框 圆角矩形框组件是页面布局中常常用到的,利用CSS3的border-radius可非常方便的创建. 并且在横向纵向上面都有很好的扩展性和灵活性. ...

  9. 用wxpy管理微信公众号,并利用微信获取自己的开源数据。

    之前了解到itchat 乃至于 wxpy时 是利用tuling聊天机器人的接口.调用接口并保存双方的问答结果可以作为自己的问答词库的一个数据库累计.这些数据可以用于自己训练. 而最近希望获取一些语音资 ...

  10. python 接口测试环境准备

    1.之前用python做appium测试,今天想要尝试下做接口测试 发现在pycharm下,import requests总是报错 : no  model named requests 联想到应该是没 ...