使用hystrix实现多服务之间的调用出现异常的情况,及时预警

在 使用Feign来实现SpringCloud多模块之间的调用 这篇文章我写了如何去调用,但是并没有考虑异常宕机的情况。

比如:快手系统里面调用头条数据,但是头条系统宕机了要如何处理。

第一步:在公共父类中引入hystrix

<!-- Hystrix -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
        </dependency>

第二步:在启动类上添加@EnableCircuitBreaker注解

第三步:实现自己编写的feign接口类

实现这个接口,并将实现类标记为@Component,这里我专门创建一个包来放这个class

 第四步:在自己编写的接口上引入这个实现类

 第五步:配置配置文件,增加

feign:
  hystrix:
    enabled: true

 

把头条系统关闭后,在访问就会提示:

在写这发现在请求超过1s时,就会一直进入预警代码,就是一直打印“头条系统出现问题了”,看源码视频才发现Histrix也有默认时间为1s,所以需要在配置文件中去修改这个时间,所以这里要重新设置下。

hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            timeoutInMilliseconds: 2000

这样再次访问就不会进入预警了。

上面的这种方式,是预警了被调用的系统,那如果自己的系统出现了问题呢?采用@HystrixCommand来实现

第一步:创建一个参数和返回是一模一样的方法,里面的具体内容自己定义

 第二步:在方法上引入

 

说明:只有getDataById这个方法出现异常了,才会走getDataByIdError这个方法,这里data.get("data").toString()当值为null时,会出现异常,也就是头条系统返回的值为null

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值