Hystrix:熔断器,容错管理工具,旨在通过熔断机制控制服务和第三方库的节点,从而对延迟和故障提供更强大的容错能力。

说到熔断器,先要引入另外一个词,雪崩效应。

雪崩效应,百度百科的解释是这样的:

登山时,决不能顺着山边扔石子儿。一是有击中别人的危险,一枚从数千英尺落下的小石头,破坏力相当惊人;二是有可能引发雪崩,一枚不起眼的小石子儿,顶多只能撞动几块差不多大小的石头;但只要有足够数量的石头翻滚起来,用不了多久,大块大块的岩石也会松动下滑。于是乎,这一颗小小的石子儿,就能引发一场雪崩。这个道理不言自明,好比就是水滴石穿、蝴蝶效应,说的都是一个小因素的变化,却往往有着无比强大的力量,以至于最后改变整体结构、产生意想不到的结果。现在,把这个原理适用于商业和技术领域,它同样能得到类似的效果—商业和技术本身具有一定的结构和体系,当人们适当地拆散其结构,并予以重新组合,便能释放出犹如雪崩般巨大的能量。雪崩把旧有的产业体系打得粉碎,甚至,有时候干脆让整个产业消失。在雪崩的巨大压力下,商业与技术之间固有的联系被彻底中断,不得不接受新的改造和整合,其最终将引爆一系列创新的革命,这就是“雪崩效应”。
以上来自百度百科。

从上面可以看到,造成雪崩效应很可能就是因为一个特别小的原因,比如一个石子。然后让我们在看一下下图:

图中每个字母代表了一个微服务,剪头代表服务的调用。
假设1:
服务G由于某种原因瘫痪了,可以看出来影响的是服务M无法调用服务G,可能说某种意义上,影响的只是单服务,光看图可能没那么大影响。
假设2:
服务B瘫痪了,从图中能够发现上半区的所有服务都要瘫痪。
假设3:
最坏的可能,服务A瘫痪了,服务A的瘫痪导致B,C,D全部瘫痪,连锁反应造成所有服务都死了,造成整个系统的瘫痪。

为了不让这样的事情发生,springcloud中提供了Hystrix熔断器,即在失败率达到阈值时(默认为5秒内20次失败),自动调用回调方法,使请求快速返回。

举一个通俗的例子,大家都能遇到这样的情况,家里的用电量过高的时候,会出现“跳闸”,为什么出现跳闸,就是因为长期用电量过高,会出现超载,长期这样就会升温,引起火灾等不好的连锁反应。

下面介绍一下ribbon整合断路器:

新建一个项目springcloud_hystric_ribbon,项目在springboot_ribbon上做了简单的修改,pom文件中加入hystrix,pom文件代码如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.dalaoyang</groupId><artifactId>springcloud_hystric_ribbon</artifactId><version>0.0.1-SNAPSHOT</version><packaging>jar</packaging><name>springcloud_hystric_ribbon</name><description>springcloud_hystric_ribbon</description><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>1.5.9.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding><java.version>1.8</java.version><spring-cloud.version>Edgware.SR1</spring-cloud.version></properties><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-eureka</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-ribbon</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-hystrix</artifactId></dependency></dependencies><dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>${spring-cloud.version}</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>

配置文件如下:

##端口号
server.port=8764##服务名称
spring.application.name=springcloud_hystric_ribbon##注册中心地址
eureka.client.service-url.defaultZone=http://eureka.dalaoyang.cn/eureka/

启动类加入注解@EnableHystrix开启熔断器,然后在之前的方法上加上注解 @HystrixCommand(fallbackMethod = "indexError"),其中fallbackMethod是在调用失败时的回调方法。代码如下:

package com.dalaoyang;import com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand;
import com.netflix.ribbon.proxy.annotation.Hystrix;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.hystrix.EnableHystrix;
import org.springframework.context.annotation.Bean;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate;@SpringBootApplication
@EnableEurekaClient
@RestController
@EnableHystrix
public class SpringcloudHystricRibbonApplication {public static void main(String[] args) {SpringApplication.run(SpringcloudHystricRibbonApplication.class, args);}@Bean@LoadBalancedRestTemplate restTemplate() {return new RestTemplate();}@Value("${server.port}")String port;@Value("${spring.application.name}")String serviceName;@HystrixCommand(fallbackMethod = "indexError")@GetMapping("/")public String index(){return restTemplate().getForObject("http://service/",String.class);}public String indexError(){return "调用服务失败!";}
}

启动服务,访问http://localhost:8764/,可以看到响应如下:

接下来说一下feign的熔断器使用,其实上一篇文章已经使用了断路器,这里就不具体介绍了,如果需要可以看我的上一篇文章--《声明式调用---Feign》

然后我们在改造一下springcloud_hystric_ribbon项目,加入Hystrix Dashboard仪表盘,pom文件中加入依赖:


<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId>
</dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-hystrix-dashboard</artifactI>
</dependency>

启动类加入@EnableHystrixDashboard启动仪表盘。启动项目,访问http://localhost:8764/hystrix

可以看到下图

上面填写http://localhost:8764/hystrix.stream,title随便填写一下即可,然后点击Monitor Stream,看到下图

这是发现一直在loading,不要着急,在打开一个窗口请求一下http://localhost:8764/,然后在看一下仪表盘,如下图所示:

源码下载 :大老杨码云

个人网站:https://dalaoyang.cn

转载于:https://www.cnblogs.com/dalaoyang/p/8900954.html

熔断器---Hystrix相关推荐

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

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

  2. 《深入理解 Spring Cloud 与微服务构建》第九章 熔断器 Hystrix

    <深入理解 Spring Cloud 与微服务构建>第九章 熔断器 Hystrix 文章目录 <深入理解 Spring Cloud 与微服务构建>第九章 熔断器 Hystrix ...

  3. springcloud 熔断器Hystrix的具体使用

    springcloud 熔断器Hystrix的具体使用 说起springcloud熔断让我想起了去年股市中的熔断,多次痛的领悟,随意实施的熔断对整个系统的影响是灾难性的,好了接下来我们还是说正事. 熔 ...

  4. 【微服务】微服务熔断器--Hystrix

    微服务熔断器--Hystrix 前言 什么是熔断? 什么是降级? 熔断和降级的区别 Hystrix的隔离机制? 什么是Fallback? 熔断器的使用 导入依赖 启动类开启Hystrix配置 声明服务 ...

  5. 关于熔断器Hystrix替代方案的调研报告

    关于熔断器Hystrix替代方案的调研报告 一.背景 Netflix宣布停止Hystrix熔断器的开发,目前进入了维护模式.同时,也指出了Hystrix 1.5.18版本足够满足现阶段的应用(详细请参 ...

  6. 第六章 服务熔断器Hystrix

    6-1.Hystrix是什么? ​   在微服务的框架中,我们是将一个单体应用拆分成多个服务单元,各个服务单元之间通过注册中心彼此发现和消费对方提供的服务,每个服务器单元都是单独部署,在各自服务的运行 ...

  7. SpringCloud使用熔断器Hystrix

    文章目录 1. 配置 1.1 远程调用配置 1.2 测试远程调用 1.3 使用熔断器Hystrix 1.4 测试熔断器 1. 配置 Feign是简化Java HTTP客户端开发的工具(java-to- ...

  8. 熔断器hystrix的使用

    一.restTemplate+ribbon使用hystrix 1.引入依赖 <dependency><groupId>org.springframework.cloud< ...

  9. SpringCloud组件之熔断器Hystrix的理论与实操

    本篇博客主要讲解Hystrix的理论以及实现. 首先先来讲熔断器Hystrix的理论以及两种实现方法. 熔断器理论 为什么使用熔断器 分布式系统面临的问题:雪崩效应 在微服务架构中通常会有多个服务层调 ...

  10. [菜鸟SpringCloud实战入门]第五章:熔断器Hystrix的使用 + 可视化监控Hystrix Dashboard和Turbine

    前言 欢迎来到菜鸟SpringCloud实战入门系列(SpringCloudForNoob),该系列通过层层递进的实战视角,来一步步学习和理解SpringCloud. 本系列适合有一定Java以及Sp ...

最新文章

  1. 拥抱人工智能报告:中国未来就业的挑战与应对
  2. Spring MVC拦截器实现
  3. java课堂疑问解答与思考2
  4. Spring Environment
  5. 人脸识别三大经典算法_人脸识别系列四 | DeepID1算法
  6. # 睡眠3秒_【for fun】睡眠排序算法
  7. 数据拆分_数据拆分,偏方请拿好
  8. 网络基础2-2(传输层,端口,详谈UDP)
  9. 文远知行公布自动驾驶运营路线图:全新升级自动驾驶方案,建立500辆规模的自动驾驶车队...
  10. sql优化常见的几种思路
  11. 立林门禁读卡器接线图_立林楼宇对讲维修方法—常见故障的解决方法
  12. 易语言组合框基本属性方法事件
  13. python注释可用于表明作者和版权信息_vs2017 新建Class 文件时,自动添加作者版权声明注释...
  14. vue文件上传(单文件以及多文件)
  15. 300句子与7000单词
  16. 第二期项目订房网错误分析
  17. day12-HTML、CSS与blog页面讲解
  18. java 广告sdk开发_supersonicads广告sdk逆向分析以及无源码debug java
  19. BOOT ROM 初始化内容、启动设备、镜像烧写
  20. 《金融怪杰》读书笔记

热门文章

  1. Mybatis的jdbc参数设置
  2. 高德地图 街道范围_高德地图发布交通“评诊治”系统:针对各类交通拥堵场景“因地制宜”...
  3. Vuex的store中的Module
  4. python360百科_python抓取360百科踩过的坑!
  5. java8获取实现某个接口的所有类_Java 试题八
  6. 一阶电路误差分析_读图学电路原理为什么交流调理电路会产生滞后,直流偏置又是什么...
  7. power系列服务器问题品管主任,了解 Power BI 管理员角色
  8. linux数据库创建表空间语句,如何用LINUX用命令创建ORACLE数据库表空间和用户
  9. java参数传入泛型类型_Java 泛型(参数化类型)
  10. 从零开始搭建spring-cloud(2) ----ribbon