一、熔斷器簡(jiǎn)介
微服務(wù)架構(gòu)特點(diǎn)就是多服務(wù),多數(shù)據(jù)源,支撐系統(tǒng)應(yīng)用。這樣導(dǎo)致微服務(wù)之間存在依賴關(guān)系。如果其中一個(gè)服務(wù)故障,可能導(dǎo)致系統(tǒng)宕機(jī),這就是所謂的雪崩效應(yīng)。
1、服務(wù)熔斷
微服務(wù)架構(gòu)中某個(gè)微服務(wù)發(fā)生故障時(shí),要快速切斷服務(wù),提示用戶,后續(xù)請(qǐng)求,不調(diào)用該服務(wù),直接返回,釋放資源,這就是服務(wù)熔斷。
熔斷生效后,會(huì)在指定的時(shí)間后調(diào)用請(qǐng)求來測(cè)試依賴是否恢復(fù),依賴的應(yīng)用恢復(fù)后關(guān)閉熔斷。
2、服務(wù)降級(jí)
服務(wù)器高并發(fā)下,壓力劇增的時(shí)候,根據(jù)當(dāng)業(yè)務(wù)情況以及流量,對(duì)一些服務(wù)和頁(yè)面有策略的降級(jí)(可以理解為關(guān)閉不必要的服務(wù)),以此緩解服務(wù)器資源的壓力以保障核心任務(wù)的正常運(yùn)行。
雙十一期間,支付寶很多功能都會(huì)提示,[雙十一期間,保障核心交易,某某服務(wù)數(shù)據(jù)延遲]。
3、核心依賴
1
2
3
4
|
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId> </dependency> |
4、核心注解
•@EnableHystrix 啟動(dòng)類注解控制熔斷功能。
•@HystrixCommand 方法注解,熔斷控制配置。
5、案例模塊描述
演示基于Ribbon服務(wù)的熔斷
node03-consume-8001
演示基于Feign服務(wù)的熔斷
node03-consume-8002
Eureka注冊(cè)中心
node03-eureka-7001
兩個(gè)服務(wù)提供方
node03-provider-6001
node03-provider-6002
二、基于Ribbon服務(wù)熔斷
1、熔斷執(zhí)行方法
1
2
3
4
5
6
|
/** * 服務(wù)熔斷調(diào)用方法 */ public String getDefaultInfo (){ return "服務(wù)被熔斷" ; } |
2、簡(jiǎn)單案例
1
2
3
4
5
6
7
8
|
/** * 簡(jiǎn)單配置 */ @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),就會(huì)執(zhí)行熔斷,進(jìn)入fallback程序。由于Spring的懶加載機(jī)制,首次請(qǐng)求往往比較慢,可以通過配置Hystrix超時(shí)時(shí)間解決。
3、復(fù)雜案例
•配置超時(shí)、并發(fā)、線程池、指定異常熔斷忽略
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
/** * 復(fù)雜配置 */ @RequestMapping ( "/showInfo2" ) @HystrixCommand ( fallbackMethod = "getDefaultInfo" , commandProperties={ // 降級(jí)處理超時(shí)時(shí)間設(shè)置 @HystrixProperty (name = "execution.isolation.thread.timeoutInMilliseconds" , value = "3000" ), // 任意時(shí)間點(diǎn)允許的最高并發(fā)數(shù)。超過該設(shè)置值后,拒絕執(zhí)行請(qǐng)求。 @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 = "" ; // 測(cè)試配置異常不熔斷 // 響應(yīng):{"code":500,"msg":"運(yùn)行異常"} if (value.equals( "" )){ throw new ServiceException( "運(yùn)行異常" ) ; } // 該異常被熔斷 // if (value.equals("")){ // throw new RuntimeException("拋出錯(cuò)誤") ; // } return restTemplate.getForObject(server_name+ "/getInfo" ,String. class ) ; } |
4、啟動(dòng)類注解
•@EnableHystrix
三、基于Feign服務(wù)熔斷
1、Jar包說明
通過觀察Fegin依賴的JAR可知,F(xiàn)egin的Jar下包含Hystrix需要的Jar包,這里不用再次導(dǎo)入依賴。
2、熔斷配置
Feign用接口實(shí)現(xiàn)的聲明式Rest請(qǐng)求,所以配置也就在接口上面了。
1)、接口代碼
1
2
3
4
5
|
@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í)行代碼
1
2
3
4
5
6
7
|
@Component public class FallbackService implements GetAuthorService { @Override public String getAuthorInfo(String authorId) { return "服務(wù)被熔斷" +authorId; } } |
3)、配置文件
•開啟熔斷功能
1
2
3
|
feign: hystrix: enabled: true |
3、服務(wù)類注解
由于上面的接口和熔斷代碼是在不同的Jar模塊中,所以要在啟動(dòng)類@SpringBootApplication注解中掃描,如下。
1
2
3
4
5
6
7
8
9
10
|
@SpringBootApplication (scanBasePackages = { "cloud.node02.consume" , "cloud.block.code.service" }) @EnableEurekaClient // 本服務(wù)啟動(dòng)后會(huì)自動(dòng)注冊(cè)進(jìn)eureka服務(wù)中 @EnableDiscoveryClient // 因?yàn)榘窂讲煌?,需要加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/spring-cloud-base
碼云地址:知了一笑
https://gitee.com/cicadasmile/spring-cloud-base
總結(jié)
以上所述是小編給大家介紹的SpringCloud微服務(wù)之Hystrix組件實(shí)現(xiàn)服務(wù)熔斷的方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)服務(wù)器之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
原文鏈接:https://www.cnblogs.com/cicada-smile/archive/2019/08/02/11286451.html