本文源碼:GitHub·點(diǎn)這里 || GitEE·點(diǎn)這里
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專(zhuān)注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、小程序開(kāi)發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶(hù)創(chuàng)新互聯(lián)還提供了涿州免費(fèi)建站歡迎大家使用!
微服務(wù)架構(gòu)特點(diǎn)就是多服務(wù),多數(shù)據(jù)源,支撐系統(tǒng)應(yīng)用。這樣導(dǎo)致微服務(wù)之間存在依賴(lài)關(guān)系。如果其中一個(gè)服務(wù)故障,可能導(dǎo)致系統(tǒng)宕機(jī),這就是所謂的雪崩效應(yīng)。
微服務(wù)架構(gòu)中某個(gè)微服務(wù)發(fā)生故障時(shí),要快速切斷服務(wù),提示用戶(hù),后續(xù)請(qǐng)求,不調(diào)用該服務(wù),直接返回,釋放資源,這就是服務(wù)熔斷。
熔斷生效后,會(huì)在指定的時(shí)間后調(diào)用請(qǐng)求來(lái)測(cè)試依賴(lài)是否恢復(fù),依賴(lài)的應(yīng)用恢復(fù)后關(guān)閉熔斷。
服務(wù)器高并發(fā)下,壓力劇增的時(shí)候,根據(jù)當(dāng)業(yè)務(wù)情況以及流量,對(duì)一些服務(wù)和頁(yè)面有策略的降級(jí)(可以理解為關(guān)閉不必要的服務(wù)),以此緩解服務(wù)器資源的壓力以保障核心任務(wù)的正常運(yùn)行。
雙十一期間,支付寶很多功能都會(huì)提示,[雙十一期間,保障核心交易,某某服務(wù)數(shù)據(jù)延遲]。
org.springframework.cloud
spring-cloud-starter-hystrix
演示基于Ribbon服務(wù)的熔斷
node03-consume-8001
演示基于Feign服務(wù)的熔斷
node03-consume-8002
Eureka注冊(cè)中心
node03-eureka-7001
兩個(gè)服務(wù)提供方
node03-provider-6001
node03-provider-6002
/**
* 服務(wù)熔斷調(diào)用方法
*/
public String getDefaultInfo (){
return "服務(wù)被熔斷" ;
}
/**
* 簡(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)求往往比較慢,可以通過(guò)配置Hystrix超時(shí)時(shí)間解決。
/**
* 復(fù)雜配置
*/
@RequestMapping("/showInfo2")
@HystrixCommand(
fallbackMethod = "getDefaultInfo",
commandProperties={
// 降級(jí)處理超時(shí)時(shí)間設(shè)置
@HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "3000"),
// 任意時(shí)間點(diǎn)允許的最高并發(fā)數(shù)。超過(guò)該設(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) ;
}
通過(guò)觀察Fegin依賴(lài)的JAR可知,F(xiàn)egin的Jar下包含Hystrix需要的Jar包,這里不用再次導(dǎo)入依賴(lài)。
Feign用接口實(shí)現(xiàn)的聲明式Rest請(qǐng)求,所以配置也就在接口上面了。
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 {
@Override
public String getAuthorInfo(String authorId) {
return "服務(wù)被熔斷"+authorId;
}
}
3)、配置文件
feign:
hystrix:
enabled: true
由于上面的接口和熔斷代碼是在不同的Jar模塊中,所以要在啟動(dòng)類(lèi)@SpringBootApplication注解中掃描,如下。
@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