Hystrix微服务容错率和监控

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项目后,才有监控数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值