Hystrix微服务容错率和监控
功能,作用:
由于整个项目是由多个微服务组成的,并且调用关系非常复杂,一个大的项目可能由几十个几百个甚至几千个微服务组成,某个微服务如果在某个节点运行缓慢,或者出现其他问题,由于调用关系复杂,有可能造成大面积瘫痪,也就是说会产生雪崩效应
Hystrix主要是为了在某个微服务出现故障的时候,不至于影响其他服务,产生大面积瘫痪,防止雪崩
简单来说,主要功能是增加系统容错率的
添加依赖
直接右键项目添加Spring起步依赖即可:Hystrix[maintenance]
启动类配置
启动类上加入一个注解:
@EnableCircuitBreaker
当在主启动类上有以下注解时候,可以合并
@EnableCircuitBreaker
@EnableDiscoveryClient
@SpringBootApplication
可以合并为:
@SpringCloudApplication
降级
后台服务器出错或者超时,可以执行另一段代码,向客户端返回响应
降级响应,可以是错误提示,也可以返回缓存数据
实现降级代码只需要在Controller中,某个方法上,再加入一个注解:
@HystrixCommand(fallbackMethod="降级方法的方法名")
注意:降级方法的返回值,接受的参数,需要和原方法一致,如果参数中有注解,可以把注解删掉,方法名称可以随意指定,一般在原方法名后面加一个FB
熔断
在默认条件下(参数可以配置),满足2个请求
1.10秒内产生20次请求(必须首先满足)
2.50%失败,并执行降级代码
达成这两个条件后会直接触发熔断,所有请求在前一个Provider中不会向坏的Provider发送请求,而是会直接执行降级代码向前返回结果
半开状态:(一般是5秒进入半开状态)
在半开状态下,会尝试发送依次请求,如果连接成功,则会关闭断路器,恢复正常状态
超时时间配置的注意事项
Hystrix有默认超时时间,默认为1000ms
具体配置超时时间:yml文件
hystrix:
command:
default:
execution:
isolation:
thread:
timeoutInMilliseconds: 500
当配置了Ribbon的超时时间大于1秒,Hystrix的超时时间是1秒,当超过Hystrix的超时时间后,立刻会执行降级方法,然而这个时候,Ribbon还在重复连接,即使得到了响应结果,浏览器也只会接收到降级方法,无法返回正确响应结果
所以,我们需要把这两项的超时时间配置
所以我们需要把Hystrix的超时时间大于等于Ribbon的总超时时长
总超时时长设置为1-2秒比较合适
有另一种方法就是触发降级后不再进行重试,但是无法实现
Hystrix Dashboard
需要新起一个SpringBoot Starter项目,加入一个Hystrix DashBoard的依赖即可
配置一下yml文件,appname和port
主启动类加入注解
@EnableHystrixDashboard
完成配置,访问
http://localhost:4001/hystrix
即可查看仪表盘初始页面
页面中输入:(端口号根据项目配置)
http://localhost:3001/actuator/hystrix.stream
注意:
在hystrix项目中,需要事先添加Actuator依赖,配置监控端点,否则无法访问actuator
必须在有请求访问hystrix项目后,才有监控数据