feign直接走熔断_SpringCloud微服务面试必问:Hystrix 服务降级、熔断

27c52b84d75c48a1693426b748f21637.png

本文作者:JLSong
本文链接:https://www.cnblogs.com/songjilong/p/12770999.html

1、Hystrix是什么?

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

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

2、Hystrix 的几个概念

2.1服务降级

不让客户端等待,并立即返回一个友好的提示(服务器忙,请稍后再试)

哪些情况会发生服务降级:

  • 程序运行异常
  • 超时
  • 服务熔断引起服务降级
  • 线程池/信号量打满也会导致服务降级

2.2服务熔断

类似保险丝,电流过大时,直接熔断断电。

熔断机制是应对雪崩效应的一种微服务链路保护机制,当扇出链路的某个微服务出错不可用或者响应时间太长时,会进行服务的降级,进而熔断该节点微服务的调用,快速返回错误的响应信息,当检测到该节点微服务调用响应正常后,恢复调用链路。

服务降级 → 服务熔断 → 恢复调用链路

2.3服务限流

对于高并发的操作,限制单次访问数量

3、服务降级的用法与分析

超时导致服务器变慢:超时不再等待; 出错(宕机或程序运行出错):要有备选方案

  • 服务提供者超时了,调用者不能一直卡死等待,必须要服务降级
  • 服务提供者宕机了,调用者不能一直卡死等待,必须要服务降级
  • 服务提供者没问题,调用者自己出现故障或者有自我要求(自己的等待时间必须小于服务提供者)

3.1给服务提供方设置服务降级

1、在需要服务降级的方法上标注注解,fallbackMethod 代表回退方法,需要自己定义,@HystrixProperty 中设置的是该方法的超时时间,如果超过该事件则自动降级

当运行超时或服务内部出错都会调用回退方法

@HystrixCommand(    fallbackMethod = "timeoutHandler",     commandProperties = {    @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "3000")})public String timeout(Long id) {    int time = 3000;    try {        TimeUnit.MILLISECONDS.sleep(time);    } catch (InterruptedException e) {        e.printStackTrace();    }    //模拟异常    //int i = 10 / 0;    return "线程:" + Thread.currentThread().getName();}

2、在启动类上添加注解,开启降级

@EnableCircuitBreaker

3.2给服务消费方设置服务降级

①.添加配置

# 在feign中开启hystrixfeign:  hystrix:    enabled: true

②.和服务提供方一样,照葫芦画瓢

@HystrixCommand(    fallbackMethod = "timeoutHandler",     commandProperties = {    @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "1500")})public String timeout(@PathVariable("id") Long id) {    int i = 1/0;    return hystrixService.timeout(id);}

③.在启动类上添加注解

@EnableHystrix

3.3问题

以上配置方式存在的问题:

  • 每个业务方法对应一个回退方法,代码膨胀
  • 每个业务方法上都配置相同的处理,代码冗余

解决方式1:在类上配置一个全局回退方法,相当于是一个通用处理,当此回退方法能满足你的需求,就无需在方法上指定其它回退方法,如果需要使用特定的处理方法可以再在业务方法上定义

@DefaultProperties(defaultFallback = "globalFallbackMethod")

解决方式2:但此时处理代码和依然和业务代码混合在一起,我们还可以使用另一种方式:编写一个类实现 Feign 的调用接口,并重写其方法作为回退方法,然后在 @FeignClient 注解上添加 fallback 属性,值为前面的类。

4、服务熔断的用法与分析

在SpringCloud中,熔断机制通过 Hystrix 实现。Hystrix 监控微服务间的调用状况,当失败的调用到一定阈值,默认 5 秒内 20 次调用失败就会启动熔断机制。熔断机制的注解是 @HystrixCommand

@HystrixCommand(    fallbackMethod = "paymentCircuitBreakerFallback",     commandProperties = {        @HystrixProperty(name = "circuitBreaker.enabled", value = "true"), //是否开启断路器        @HystrixProperty(name = "circuitBreaker.requestVolumeThreshold", value = "10"), //请求次数        @HystrixProperty(name = "circuitBreaker.sleepWindowInMilliseconds", value = "10000"), //时间窗口期        @HystrixProperty(name = "circuitBreaker.errorThresholdPercentage", value = "60") //失败率达到多少后跳闸})public String circuitBreaker(Long id) {    if (id < 0) {        throw new RuntimeException("id 不能为负数");    }    return Thread.currentThread().getName() + "" + "调用成功,流水号:" + IdUtil.simpleUUID();}public String circuitBreakerFallback(Long id) {    return "id 不能为负数,你的id = " + id;}

@HystrixProperty 中的配置可以参考 com.netflix.hystrix.HystrixCommandProperties 类

详见官方文档:https://github.com/Netflix/Hystrix/wiki/Configuration

也有雷锋同志做了翻译:https://www.jianshu.com/p/39763a0bd9b8

熔断类型

  • 熔断打开:请求不再调用当前服务,内部设置时钟一般为MTTR(平均故障处理时间),当打开时长达到所设时钟则进入半熔断状态。
  • 熔断半开:部分请求根据规则调用服务,如果请求成功且符合规则,则关闭熔断。
  • 熔断关闭:不会对服务进行熔断。

断路器什么时候起作用?

根据上面配置的参数,有三个重要的影响断路器的参数

  • 快照时间窗:回路被打开、拒绝请求到再尝试请求并决定回路是否继续打开的时间范围,默认是 5 秒
  • 请求总数阈值:在一个滚动窗口中,打开断路器需要的最少请求数,默认是 20 次(就算前 19 次都失败了,断路器也不会被打开)
  • 错误百分比阈值:错误请求数在总请求数所占的比例,达到设定值才会触发,默认是 50%

断路器开启或关闭的条件

  1. 当请求达到一定阈值时(默认 20 次)
  2. 当错误率达到一定阈值时(默认 50%)
  3. 达到以上条件断路器开启
  4. 当开启的时候,所有请求都不会转发
  5. 当断路器开启一段时间后(默认 5 秒)进入半开状态,并让其中一个请求进行转发,如果成功断路器关闭,如果失败继续开启,重复第 4 和 5 步

断路器开启之后会发生什么?

  • 再有请求调用时,不再调用主逻辑,而是调用降级 fallback。
  • 断路器开启之后,Hytrix 会启动一个休眠时间窗,在此时间内,fallback 会临时称为主逻辑,当休眠期到了之后,断路器进入半开状态,释放一个请求到原来的主逻辑上,如果请求成功返回,则断路器关闭,如果请求失败,则继续进入打开状态,休眠时间窗重新计时。

5、Hystrix服务熔断的工作流程

62349b225803a6783c5e1be9028f0607.png

详见官方文档:https://github.com/Netflix/Hystrix/wiki/How-it-Works

6、Hystrix DashBoard 上手

6.1搭建

①.新建一个项目,导入 maven 依赖

org.springframework.cloud    spring-cloud-netflix-hystrix-dashboardorg.springframework.boot    spring-boot-starter-actuator

②.添加配置

server:  port: 9001

③.开启 Hystrix DashBoard

@SpringBootApplication@EnableHystrixDashboardpublic class ConsumerHystrixDashBoard9001 {    public static void main(String[] args){        SpringApplication.run(ConsumerHystrixDashBoard9001.class, args);    }}

④.浏览器输入 http://localhost:9001/hystrix,出现以下界面即启动成功

9cd8f7077d24f0d22ff55a57f52a3d7c.png

7、使用

注意:想要被 Hystrix DashBoard 监控的服务必须导入此依赖

org.springframework.boot    spring-boot-starter-actuator

在被监控服务的主启动类里添加如下代码,否则某些旧版本可能报错 Unable to connect to Command Metric Stream.

/** * 此配置是为了服务监控而配置,与服务容错本身无关,SpringCloud升级后的坑 * ServletRegistrationBean因为springboot的默认路径不是"/hystrix.stream", * 只要在自己的项目里配置上下面的servlet就可以了 */@Beanpublic ServletRegistrationBean getServlet(){    HystrixMetricsStreamServlet streamServlet = new HystrixMetricsStreamServlet();    ServletRegistrationBean registrationBean = new ServletRegistrationBean(streamServlet);    registrationBean.setLoadOnStartup(1);    registrationBean.addUrlMappings("/hystrix.stream");    registrationBean.setName("HystrixMetricsStreamServlet");    return registrationBean;}

在 Hystrix DashBoard 页面输入基本信息,进入仪表盘界面

6d64808812960f4e8d687268d7afa0c3.png

大致情况如下所示

41aa4863df7df208ab48a2bd809e214e.png

操作界面分析:

f83f838a11a2e205aee5b734bb8c9fce.png

代码地址:https://github.com/songjilong/springcloud-hoxton-learning

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/575033.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

httpServlet,java web后台服务

1&#xff0c;定时执行的类 package com.utils;import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Date; public class MyTimer extends Thread {// 间隔时间&#xff1a;小时private int intervalHours;// 误差(操作所需时间可能导致误差)&am…

mysql 会话级别的参数_PostgreSQL的参数设置级别及查询各级别的参数值

PostgreSQL的参数设置级别及查询各级别的参数值系统级别用户/角色级别用户/角色 数据库级别会话级别1.查询某参数在系统级别的设置直接到postgresql.conf中去过滤2.查询某参数在某用户级别的设置testdb# create user testa password testa;CREATE ROLETime: 85.415 mstestdb# …

【开源项目10】安卓图表引擎AChartEngine

安卓图表引擎AChartEngine(一) - 简介 http://blog.csdn.net/lk_blog/article/details/7645509 安卓图表引擎AChartEngine(二) - 示例源码概述和分析 http://blog.csdn.net/lk_blog/article/details/7642751 安卓图表引擎AChartEngine(三) - 示例源码折线图、饼图和柱状图 http…

python里面print是什么意思_python里print是什么意思

python里print是什么意思,多个,是一个,对象,默认值,一个函数 python里print是什么意思 易采站长站&#xff0c;站长之家为您整理了python里print是什么意思的相关内容。 Python是一种解释型、面向对象、动态数据类型的高级程序设计语言。Python由Guido van Rossum于1989年底发明…

mysql 用户管理系统_mysql 用户管理

MySQL账户管理在我们之前登录MySQL的时候我们都是直接使用的root用户&#xff0c;root用户属于数据库系统中的超级管理员&#xff0c;有权限对mysql进行任何想要做的操作。如果在生产环境下操作数据库时也是全部直接使用root账户连接&#xff0c;这就和悬崖边跳舞差不多。所以 …

执行一次怎么会写入两次数据_浅谈 Redis 数据持久化之 AOF 模式

我们知道 Redis 之所以读写快、性能高&#xff0c;得益于它是一种基于内存的数据库&#xff0c;毫无疑问它的操作都几乎都是基于内存。但是内存型数据库也有一个很大的弊端&#xff1a;如果进程崩溃或者服务重启的时候内存数据得不到保存&#xff0c;就会造成数据丢失。为了解决…

poj 2965 The Pilots Brothers' refrigerator

http://poj.org/problem?id2965 poj 1753扩展&#xff0c;dfs枚举&#xff0c;不过加了一个路径。 The Pilots Brothers refrigeratorTime Limit: 1000MS Memory Limit: 65536KTotal Submissions: 19278 Accepted: 7384 Special JudgeDescription The game “The Pilots Broth…

mysql5.7简要介绍_MySQL 5.7新特性介绍

1. 介绍身处MySQL这个圈子&#xff0c;能够切身地感受到大家对MySQL 5.7的期待和热情&#xff0c;似乎每个人都迫不及待的想要了解、学习和使用MySQL 5.7。那么&#xff0c;我们不禁要问&#xff0c;MySQL 5.7到底做了哪些改进&#xff0c;引入了哪些新功能&#xff0c;性能又提…

数字化转型方法论_双中台:企业数字化转型的核心战略与方法论

当下&#xff0c;绝大部分企业的组织形态、经营模式基本都是垂直闭环型&#xff0c;即围绕一种业务或者管理&#xff0c;其计划、执行、检查、优化的闭环都是独立于企业生态之中。在过去的“局部竞争”、“渠道为王”、“终端为王”的时代&#xff0c;这种组织与经营形式很好地…

java ee自学路线

本站文章为 Kenan 原创&#xff0c;转载请注明转自 Kenan的博客 http://kenan1992.qzone.qq.com 首先声明对于什么java ee的 自学不需要编程的基础&#xff0c;但是需要你的刻苦和努力&#xff0c;付出100%的努力&#xff0c;相信你终会有收获的那一天&#xff01;&#xff01;…

java获取cpu使用率_再一次生产 CPU 高负载排查实践

前言前几日早上打开邮箱收到一封监控报警邮件&#xff1a;某某 ip 服务器 CPU 负载较高&#xff0c;请研发尽快排查解决&#xff0c;发送时间正好是凌晨。其实早在去年我也处理过类似的问题&#xff0c;并记录下来&#xff1a;《一次生产 CPU 100% 排查优化实践》不过本次问题产…

《BI那点儿事》三国数据分析系列——蜀汉五虎上将与魏五子良将武力分析,绝对的经典分析...

《BI那点儿事》三国数据分析系列——蜀汉五虎上将与魏五子良将武力分析&#xff0c;绝对的经典分析 原文:《BI那点儿事》三国数据分析系列——蜀汉五虎上将与魏五子良将武力分析&#xff0c;绝对的经典分析献给广大的三国爱好者们&#xff0c;希望喜欢三国的朋友一起讨论&#…

java map取值_Java Set接口 Map 与枚举

Set接口概述一个不包含重复元素的 collection。更确切地讲&#xff0c;set 不包含满足 e1.equals(e2) 的元素对 e1 和 e2&#xff0c;并且最多包含一个 null 元素特点Set接口是无序的 Set 是继承于Collection的接口。它是一个不允许有重复元素的集合。Set可以存储null值,但是nu…

网路工程师要不要学mysql_网络工程师要学什么_网络工程师需要的技能

如果以后想从事网络工程师这个岗位&#xff0c;同学们知道 网络工程师要学什么 吗&#xff1f;本期乔布 网络工程师需要的技能 。关键词&#xff1a; 网络工程师要学什么 &#xff0c; 网络工程师需要的技能网络基础知识&#xff1a;深度网络基本概念&#xff0c;例如>ISO/O…

python执行效果_使用tqdm显示Python代码执行进度功能

在使用Python执行一些比较耗时的操作时&#xff0c;为了方便观察进度&#xff0c;通常使用进度条的方式来可视化呈现。Python中的tqdm就是用来实现此功能的。先来看看tqdm的进度条效果&#xff1a;tqdm的基本用法tqdm最主要的用法有3种&#xff0c;自动控制、手动控制或者用于脚…

cookiesession

cookie机制采用的是在客户端保持状态的方案&#xff0c;而session机制采用的是在服务器端保持状态的方案。 由于采用服务器端保持状态的方案在客户端也需要保存一个标识&#xff0c;所以session机制可能需要借助于cookie机制来达到保存标识的目的&#xff0c;但实际上它还有其他…

python的应用图标_python实现根据图标提取分类应用程序实例

本文实例讲述了python实现根据图标提取分类应用程序&#xff0c;分享给大家供大家参考。具体方法如下&#xff1a;#!/usr/bin/python# -*- coding: utf-8 -*-import Imageimport win32uiimport win32guidef make_regalur_image(img, size (256, 256)):return img.resize(size)…

linux调用ocx插件_Wordpress file manager插件任意文件上传

白斩鸡卫兵实验室近日&#xff0c;Wordpress 插件file manager被爆出严重0day漏洞&#xff0c;本着技术研究角度&#xff0c;和大家分享、探讨其漏洞原因。该修复程序已在同一天发布&#xff0c;并且WP File Manager插件6.9版通过删除允许未经授权的文件上传访问的端点来解决当…

ActiveRecord教程

(一、ActiveRecord基础) ActiveRecord是Rails提供的一个对象关系映射(ORM)层&#xff0c;从这篇开始&#xff0c;我们来了解Active Record的一些基础内容&#xff0c;连接数据库&#xff0c;映射表&#xff0c;访问数据等。   Active Record使用基本的ORM模式&#xff1a;表映…

树莓派安装mysql5.6_Linux上安装MySQL5.6

OS & MySQL的版本号和配置&#xff1a;MySQL Version: 5.6.19Linux Version: Linux boston.oracle.com 2.6.18-164.el5 #1 SMP Thu Sep 3 02:16:47 EDT 2009 i686 i686 i386 GNU/Linux一。下载MySQL安装软件。请到www.oracle.com去找DATABASE DOWNLOAD。下载MySQL须要注冊一…