溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Spring Cloud中Hystrix服務(wù)降級(jí)與異常處理的方法是什么

發(fā)布時(shí)間:2021-12-07 11:55:11 來(lái)源:億速云 閱讀:171 作者:iii 欄目:大數(shù)據(jù)

本篇內(nèi)容主要講解“Spring Cloud中Hystrix服務(wù)降級(jí)與異常處理的方法是什么”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“Spring Cloud中Hystrix服務(wù)降級(jí)與異常處理的方法是什么”吧!

服務(wù)降級(jí)

前面兩篇文章中,fallbackMethod所描述的函數(shù)實(shí)際上就是一個(gè)備胎,用來(lái)實(shí)現(xiàn)服務(wù)的降級(jí)處理,在注解中我們可以通過fallbackMethod屬性來(lái)指定降級(jí)處理的方法名稱,在自定義Hystrix請(qǐng)求命令時(shí)我們可以通過重寫getFallback函數(shù)來(lái)處理服務(wù)降級(jí)之后的邏輯。使用注解來(lái)定義服務(wù)降級(jí)邏輯時(shí),服務(wù)降級(jí)函數(shù)和@HystrixCommand注解要處于同一個(gè)類中,同時(shí),服務(wù)降級(jí)函數(shù)在執(zhí)行過程中也有可能發(fā)生異常,所以也可以給服務(wù)降級(jí)函數(shù)添加‘備胎’,如下:

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

@HystrixCommand(fallbackMethod = "error2")
public Book error1() {
    //發(fā)起某個(gè)網(wǎng)絡(luò)請(qǐng)求(可能失?。?
    return null;
}
public Book error2() {
    return new Book();
}

在實(shí)際開發(fā)中,并不是所有的請(qǐng)求都要提前預(yù)備好服務(wù)降級(jí)問題,如果我就是要將服務(wù)調(diào)用失敗的信息展示給用戶,那么此時(shí)就沒有必要添加斷路器了。

異常處理

我們?cè)谡{(diào)用服務(wù)提供者時(shí)有可能會(huì)拋異常,默認(rèn)情況下方法拋了異常會(huì)自動(dòng)進(jìn)行服務(wù)降級(jí),交給服務(wù)降級(jí)中的方法去處理,在自定義Hystrix請(qǐng)求命令的方式下,我們可以在getFallback方法中調(diào)用getExecutionException方法來(lái)獲取拋出的異常,舉個(gè)簡(jiǎn)單的例子:

@Override
protected Book getFallback() {
    Throwable executionException = getExecutionException();
    System.out.println(executionException.getMessage());
    return new Book("宋詩(shī)選注", 88, "錢鐘書", "三聯(lián)書店");
}

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

此時(shí)訪問結(jié)果如下:

Spring Cloud中Hystrix服務(wù)降級(jí)與異常處理的方法是什么  

控制臺(tái)打印的日志如下:

Spring Cloud中Hystrix服務(wù)降級(jí)與異常處理的方法是什么  

自動(dòng)進(jìn)行了服務(wù)降級(jí)。

如果我們采用了注解的方式,只需要在服務(wù)降級(jí)方法中添加一個(gè)Throwable類型的參數(shù)就能夠獲取到拋出的異常的類型,如下:

@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("百年孤獨(dú)", 33, "馬爾克斯", "人民文學(xué)出版社");
}

Spring Cloud中Hystrix服務(wù)降級(jí)與異常處理的方法是什么  

控制臺(tái)打印的日志也是/ by zero,我就不再貼圖片了。此時(shí),如果有一個(gè)異常拋出后我不希望進(jìn)入到服務(wù)降級(jí)方法中去處理,而是直接將異常拋給用戶,那么我們可以在@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("百年孤獨(dú)", 33, "馬爾克斯", "人民文學(xué)出版社");
}

此時(shí)執(zhí)行結(jié)果如下:

Spring Cloud中Hystrix服務(wù)降級(jí)與異常處理的方法是什么  

這里的實(shí)現(xiàn)原理很簡(jiǎn)單,因?yàn)橛幸粋€(gè)名叫HystrixBadRequestException的異常不會(huì)進(jìn)入到服務(wù)降級(jí)方法中去,當(dāng)我們定義了ignoreExceptions為ArithmeticException.class之后,當(dāng)拋出ArithmeticException異常時(shí),Hystrix會(huì)將異常信息包裝在HystrixBadRequestException里邊然后再拋出,此時(shí)就不會(huì)觸發(fā)服務(wù)降級(jí)方法了。

到此,相信大家對(duì)“Spring Cloud中Hystrix服務(wù)降級(jí)與異常處理的方法是什么”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI