欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

@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