日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

SpringCloud微服务(03):Hystrix组件,实现服务熔断

發(fā)布時(shí)間:2025/3/17 javascript 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SpringCloud微服务(03):Hystrix组件,实现服务熔断 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

寫在前面:閱讀本文前,你可能需要熟悉一下內(nèi)容。
微服務(wù)組件:Eureka管理注冊中心
微服務(wù)組件:Ribbon和Feign服務(wù)調(diào)用
SpringBoot系統(tǒng)異常映射處理

一、熔斷器簡介

微服務(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ā)生故障時(shí),要快速切斷服務(wù),提示用戶,后續(xù)請求,不調(diào)用該服務(wù),直接返回,釋放資源,這就是服務(wù)熔斷。

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

2、服務(wù)降級

服務(wù)器高并發(fā)下,壓力劇增的時(shí)候,根據(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-8002 Eureka注冊中心 node03-eureka-7001 兩個服務(wù)提供方 node03-provider-6001 node03-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)的超時(shí)時(shí)間是1秒,超時(shí)時(shí)間內(nèi)部響應(yīng),就會執(zhí)行熔斷,進(jìn)入fallback程序。由于Spring的懶加載機(jī)制,首次請求往往比較慢,可以通過配置Hystrix超時(shí)時(shí)間解決。

3、復(fù)雜案例

  • 配置超時(shí)、并發(fā)、線程池、指定異常熔斷忽略
/*** 復(fù)雜配置*/ @RequestMapping("/showInfo2") @HystrixCommand(fallbackMethod = "getDefaultInfo",commandProperties={// 降級處理超時(shí)時(shí)間設(shè)置@HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "3000"),// 任意時(shí)間點(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可知,Fegin的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í)行代碼

@Component public class FallbackService implements GetAuthorService {@Overridepublic 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)榘窂讲煌?#xff0c;需要加basePackages屬性 @EnableFeignClients(basePackages={"cloud.block.code.service"}) public class Application_8002 {public static void main(String[] args) {SpringApplication.run(Application_8002.class,args) ;} }

四、源代碼說明

GitHub地址:知了一笑 https://github.com/cicadasmile 碼云地址:知了一笑 https://gitee.com/cicadasmile


總結(jié)

以上是生活随笔為你收集整理的SpringCloud微服务(03):Hystrix组件,实现服务熔断的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。