@HystrixCommand使用
程序员文章站
2024-03-20 22:10:52
...
@HystrixCommand 注解 熔断处理
注:本文仅限记录本人工作过程中遇到并解决的问题,有些机制可能没有考虑到,所以不建议作为学习文章,仅仅在你遇到相同问题时提供一个思路,仅此而已。
所谓熔断就是说在远程服务调用发生异常时,能够捕获到异常,并且执行期望的流程。
1、通过feign服务调用服务,可以使用feign内置的Hystrix功能,注意需要在配置文件中需要开启此功能。代码:
feign.hystrix.enabled=true
另外需要写实现类来继承你的Feign客户端,并且实现相应接口,实现的内容就是发生异常时你需要处理的流程,也就是熔断机制。
如果程序正常执行没有异常抛出,是不会执行你自己实现的接口的。
@FeignClient(value = "${url1}",fallback = MyHystrix.class)
public interface FeignFacade {
@RequestMapping(value = "", method= RequestMethod.GET)
ResultDTO<JSONObject> sendC1Data() throws Exception;
}
url为注册到服务中心的服务名,可以配置跟我这种方式一样,配置在配置文件中,也可以直接写服务名。
@RequestMapping:服务端的具体接口地址。后面是请求方式
fallback:MyHystrix为接口FeignFacade的实现类,实现sendC1Data()方法,方法内容为熔断时需要走的流程。
2、也可以使用@HystrixCommand注解来处理
首先pom引入依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
<version>1.4.5.RELEASE</version>
</dependency>
@HystrixCommand注解是方法级别的,在你需要捕获的方法上加上注解
@HystrixCommand(fallbackMethod = "errMethod",ignoreExceptions = {ParamErrorException.class, BusinessTypeException.class})
public String myMethod(String param) throw Exception{
throw new Exception("手动抛出异常);
}
/**
* 调用服务异常执行方法
* */
private String errMethod(String param){
logger.info("熔断,调用sendC1Data服务发生异常");
/**后续流程处理*/
return "";
}
fallbackMethod:标记的是捕获异常时需要执行的方法,方法名称跟value值要一样,我这里是errMethod。
errMethod方法的参数要跟你注解的方法参数保持一致,否则会报错。而且两个方法必须要在同一个类中,由于在同一个类中,所以errMethod的修饰符没有限制
ignoreExceptions :需要过滤掉的异常类型,可根据实际需要选择加或者不加
在项目的启动类上需要加注解
@EnableCircuitBreaker