溫馨提示×

溫馨提示×

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

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

SpringCloud中怎么利用Hystrix組件實(shí)現(xiàn)服務(wù)熔斷

發(fā)布時間:2021-08-12 11:28:50 來源:億速云 閱讀:117 作者:Leah 欄目:編程語言

這篇文章將為大家詳細(xì)講解有關(guān)SpringCloud中怎么利用Hystrix組件實(shí)現(xiàn)服務(wù)熔斷,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

一、熔斷器簡介

微服務(wù)架構(gòu)特點(diǎn)就是多服務(wù),多數(shù)據(jù)源,支撐系統(tǒng)應(yīng)用。這樣導(dǎo)致微服務(wù)之間存在依賴關(guān)系。如果其中一個服務(wù)故障,可能導(dǎo)致系統(tǒng)宕機(jī),這就是所謂的雪崩效應(yīng)。

1、服務(wù)熔斷

微服務(wù)架構(gòu)中某個微服務(wù)發(fā)生故障時,要快速切斷服務(wù),提示用戶,后續(xù)請求,不調(diào)用該服務(wù),直接返回,釋放資源,這就是服務(wù)熔斷。

熔斷生效后,會在指定的時間后調(diào)用請求來測試依賴是否恢復(fù),依賴的應(yīng)用恢復(fù)后關(guān)閉熔斷。

2、服務(wù)降級

服務(wù)器高并發(fā)下,壓力劇增的時候,根據(jù)當(dāng)業(yè)務(wù)情況以及流量,對一些服務(wù)和頁面有策略的降級(可以理解為關(guān)閉不必要的服務(wù)),以此緩解服務(wù)器資源的壓力以保障核心任務(wù)的正常運(yùn)行。

雙十一期間,支付寶很多功能都會提示,[雙十一期間,保障核心交易,某某服務(wù)數(shù)據(jù)延遲]。

3、核心依賴

<dependency>  <groupId>org.springframework.cloud</groupId>  <artifactId>spring-cloud-starter-hystrix</artifactId></dependency>

4、核心注解

?@EnableHystrix 啟動類注解控制熔斷功能。?@HystrixCommand 方法注解,熔斷控制配置。

5、案例模塊描述

演示基于Ribbon服務(wù)的熔斷node03-consume-8001演示基于Feign服務(wù)的熔斷node03-consume-8002Eureka注冊中心node03-eureka-7001兩個服務(wù)提供方node03-provider-6001node03-provider-6002

二、基于Ribbon服務(wù)熔斷

1、熔斷執(zhí)行方法

/** * 服務(wù)熔斷調(diào)用方法 */public String getDefaultInfo (){  return "服務(wù)被熔斷" ;}

2、簡單案例

/** * 簡單配置 */@RequestMapping("/showInfo1")@HystrixCommand(fallbackMethod = "getDefaultInfo")public String showInfo1 (){  return restTemplate.getForObject(server_name+"/getInfo",String.class) ;}

Hystrix默認(rèn)的超時時間是1秒,超時時間內(nèi)部響應(yīng),就會執(zhí)行熔斷,進(jìn)入fallback程序。由于Spring的懶加載機(jī)制,首次請求往往比較慢,可以通過配置Hystrix超時時間解決。

3、復(fù)雜案例

?配置超時、并發(fā)、線程池、指定異常熔斷忽略

/** * 復(fù)雜配置 */@RequestMapping("/showInfo2")@HystrixCommand(    fallbackMethod = "getDefaultInfo",    commandProperties={        // 降級處理超時時間設(shè)置        @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "3000"),        // 任意時間點(diǎn)允許的最高并發(fā)數(shù)。超過該設(shè)置值后,拒絕執(zhí)行請求。        @HystrixProperty(name = "fallback.isolation.semaphore.maxConcurrentRequests", value = "1000"),    },    // 配置執(zhí)行的線城池    threadPoolProperties = {        @HystrixProperty(name = "coreSize", value = "20"),        @HystrixProperty(name = "maxQueueSize", value = "-1"),    },    // 該異常不執(zhí)行熔斷,去執(zhí)行該異常拋出的自己邏輯    ignoreExceptions = {ServiceException.class})public String showInfo2 (){  String value = "" ;  // 測試配置異常不熔斷  // 響應(yīng):{"code":500,"msg":"運(yùn)行異常"}  if (value.equals("")){    throw new ServiceException("運(yùn)行異常") ;  }  // 該異常被熔斷  // if (value.equals("")){  //   throw new RuntimeException("拋出錯誤") ;  // }  return restTemplate.getForObject(server_name+"/getInfo",String.class) ;}

4、啟動類注解

?@EnableHystrix

三、基于Feign服務(wù)熔斷

1、Jar包說明

通過觀察Fegin依賴的JAR可知,F(xiàn)egin的Jar下包含Hystrix需要的Jar包,這里不用再次導(dǎo)入依賴。

2、熔斷配置

Feign用接口實(shí)現(xiàn)的聲明式Rest請求,所以配置也就在接口上面了。

1)、接口代碼

@FeignClient(value = "NODE02-PROVIDER",fallback = FallbackService.class)public interface GetAuthorService {  @RequestMapping(value = "/getAuthorInfo/{authorId}",method = RequestMethod.GET)  String getAuthorInfo (@PathVariable("authorId") String authorId) ;}

2)、熔斷執(zhí)行代碼

@Componentpublic class FallbackService implements GetAuthorService {  @Override  public String getAuthorInfo(String authorId) {    return "服務(wù)被熔斷"+authorId;  }}

3)、配置文件

?開啟熔斷功能

feign: hystrix:  enabled: true

3、服務(wù)類注解

由于上面的接口和熔斷代碼是在不同的Jar模塊中,所以要在啟動類@SpringBootApplication注解中掃描,如下。

@SpringBootApplication(scanBasePackages = {"cloud.node02.consume","cloud.block.code.service"})@EnableEurekaClient  // 本服務(wù)啟動后會自動注冊進(jìn)eureka服務(wù)中@EnableDiscoveryClient// 因?yàn)榘窂讲煌枰觔asePackages屬性@EnableFeignClients(basePackages={"cloud.block.code.service"})public class Application_8002 {  public static void main(String[] args) {    SpringApplication.run(Application_8002.class,args) ;  }}

關(guān)于SpringCloud中怎么利用Hystrix組件實(shí)現(xiàn)服務(wù)熔斷就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

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

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

AI