转载

Spring Cloud中Hystrix的服务降级与异常处理

上篇文章我们看了自定义Hystrix请求命令的问题,使小伙伴们对Hystrix的使用有了进一步的了解,之前两篇文章都有涉及到一个叫做fallbackMethod的东西,我们之前没有细说这个东西,今天我们就来详细说说这个fallbackMethod,也就是服务降级问题。

本文是Spring Cloud系列的第十二篇文章,了解前十一篇文章内容有助于更好的理解本文:

1. 使用Spring Cloud搭建服务注册中心

2. 使用Spring Cloud搭建高可用服务注册中心

3. Spring Cloud中服务的发现与消费

4. Eureka中的核心概念

5. 什么是客户端负载均衡

6. Spring RestTemplate中几种常见的请求方式

7. RestTemplate的逆袭之路,从发送请求到负载均衡

8. Spring Cloud中负载均衡器概览

9. Spring Cloud中的负载均衡策略

10. Spring Cloud中的断路器Hystrix

11. Spring Cloud自定义Hystrix请求命令

服务降级

前面两篇文章中,fallbackMethod所描述的函数实际上就是一个备胎,用来实现服务的降级处理,在注解中我们可以通过fallbackMethod属性来指定降级处理的方法名称,在自定义Hystrix请求命令时我们可以通过重写getFallback函数来处理服务降级之后的逻辑。使用注解来定义服务降级逻辑时,服务降级函数和@HystrixCommand注解要处于同一个类中,同时,服务降级函数在执行过程中也有可能发生异常,所以也可以给服务降级函数添加‘备胎’,如下:

@HystrixCommand(fallbackMethod = "error1")
public Book test2() {
    return restTemplate.getForObject("http://HELLO-SERVICE/getbook1", Book.class);
}

@HystrixCommand(fallbackMethod = "error2")
public Book error1() {
    //发起某个网络请求(可能失败)
    return null;
}
public Book error2() {
    return new Book();
}

在实际开发中,并不是所有的请求都要提前预备好服务降级问题,如果我就是要将服务调用失败的信息展示给用户,那么此时就没有必要添加断路器了。

异常处理

我们在调用服务提供者时有可能会抛异常,默认情况下方法抛了异常会自动进行服务降级,交给服务降级中的方法去处理,在自定义Hystrix请求命令的方式下,我们可以在getFallback方法中调用getExecutionException方法来获取抛出的异常,举个简单的例子:

@Override
protected Book getFallback() {
    Throwable executionException = getExecutionException();
    System.out.println(executionException.getMessage());
    return new Book("宋诗选注", 88, "钱钟书", "三联书店");
}

@Override
protected Book run() throws Exception {
    int i = 1 / 0;
    return restTemplate.getForObject("http://HELLO-SERVICE/getbook1", Book.class);
}

此时访问结果如下:

Spring Cloud中Hystrix的服务降级与异常处理

控制台打印的日志如下:

自动进行了服务降级。

如果我们采用了注解的方式,只需要在服务降级方法中添加一个Throwable类型的参数就能够获取到抛出的异常的类型,如下:

@HystrixCommand(fallbackMethod = "error1")
public Book test2() {
    int i = 1 / 0;
    return restTemplate.getForObject("http://HELLO-SERVICE/getbook1", Book.class);
}

public Book error1(Throwable throwable) {
    System.out.println(throwable.getMessage());
    return new Book("百年孤独", 33, "马尔克斯", "人民文学出版社");
}

Spring Cloud中Hystrix的服务降级与异常处理

控制台打印的日志也是 / by zero ,我就不再贴图片了。此时,如果有一个异常抛出后我不希望进入到服务降级方法中去处理,而是直接将异常抛给用户,那么我们可以在@HystrixCommand注解中添加忽略异常,如下:

@HystrixCommand(fallbackMethod = "error1",ignoreExceptions = ArithmeticException.class)
public Book test2() {
    int i = 1 / 0;
    return restTemplate.getForObject("http://HELLO-SERVICE/getbook1", Book.class);
}

public Book error1(Throwable throwable) {
    System.out.println(throwable.getMessage());
    return new Book("百年孤独", 33, "马尔克斯", "人民文学出版社");
}

此时执行结果如下:

Spring Cloud中Hystrix的服务降级与异常处理

这里的实现原理很简单,因为有一个名叫HystrixBadRequestException的异常不会进入到服务降级方法中去,当我们定义了ignoreExceptions为ArithmeticException.class之后,当抛出ArithmeticException异常时,Hystrix会将异常信息包装在HystrixBadRequestException里边然后再抛出,此时就不会触发服务降级方法了。

OK,服务降级与异常处理我们就先说到这里,有问题欢迎留言讨论。

更多JavaEE资料请关注公众号:

Spring Cloud中Hystrix的服务降级与异常处理

原文  https://mp.weixin.qq.com/s/xifCxrMfbNREyGUOx8m-0w
正文到此结束
Loading...