@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