這篇文章主要介紹了SpringCloud微服務之Hystrix組件如何實現服務熔斷,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
微服務架構特點就是多服務,多數據源,支撐系統應用。這樣導致微服務之間存在依賴關系。如果其中一個服務故障,可能導致系統宕機,這就是所謂的雪崩效應。
1、服務熔斷
微服務架構中某個微服務發生故障時,要快速切斷服務,提示用戶,后續請求,不調用該服務,直接返回,釋放資源,這就是服務熔斷。
熔斷生效后,會在指定的時間后調用請求來測試依賴是否恢復,依賴的應用恢復后關閉熔斷。
2、服務降級
服務器高并發下,壓力劇增的時候,根據當業務情況以及流量,對一些服務和頁面有策略的降級(可以理解為關閉不必要的服務),以此緩解服務器資源的壓力以保障核心任務的正常運行。
雙十一期間,支付寶很多功能都會提示,[雙十一期間,保障核心交易,某某服務數據延遲]。
3、核心依賴
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId> </dependency>
4、核心注解
?@EnableHystrix 啟動類注解控制熔斷功能。
?@HystrixCommand 方法注解,熔斷控制配置。
5、案例模塊描述
演示基于Ribbon服務的熔斷
node03-consume-8001
演示基于Feign服務的熔斷
node03-consume-8002
Eureka注冊中心
node03-eureka-7001
兩個服務提供方
node03-provider-6001
node03-provider-6002
1、熔斷執行方法
/**
* 服務熔斷調用方法
*/
public String getDefaultInfo (){
return "服務被熔斷" ;
}2、簡單案例
/**
* 簡單配置
*/
@RequestMapping("/showInfo1")
@HystrixCommand(fallbackMethod = "getDefaultInfo")
public String showInfo1 (){
return restTemplate.getForObject(server_name+"/getInfo",String.class) ;
}Hystrix默認的超時時間是1秒,超時時間內部響應,就會執行熔斷,進入fallback程序。由于Spring的懶加載機制,首次請求往往比較慢,可以通過配置Hystrix超時時間解決。
3、復雜案例
?配置超時、并發、線程池、指定異常熔斷忽略
/**
* 復雜配置
*/
@RequestMapping("/showInfo2")
@HystrixCommand(
fallbackMethod = "getDefaultInfo",
commandProperties={
// 降級處理超時時間設置
@HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "3000"),
// 任意時間點允許的最高并發數。超過該設置值后,拒絕執行請求。
@HystrixProperty(name = "fallback.isolation.semaphore.maxConcurrentRequests", value = "1000"),
},
// 配置執行的線城池
threadPoolProperties = {
@HystrixProperty(name = "coreSize", value = "20"),
@HystrixProperty(name = "maxQueueSize", value = "-1"),
},
// 該異常不執行熔斷,去執行該異常拋出的自己邏輯
ignoreExceptions = {ServiceException.class}
)
public String showInfo2 (){
String value = "" ;
// 測試配置異常不熔斷
// 響應:{"code":500,"msg":"運行異常"}
if (value.equals("")){
throw new ServiceException("運行異常") ;
}
// 該異常被熔斷
// if (value.equals("")){
// throw new RuntimeException("拋出錯誤") ;
// }
return restTemplate.getForObject(server_name+"/getInfo",String.class) ;
}4、啟動類注解
?@EnableHystrix
1、Jar包說明
通過觀察Fegin依賴的JAR可知,Fegin的Jar下包含Hystrix需要的Jar包,這里不用再次導入依賴。
2、熔斷配置
Feign用接口實現的聲明式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)、熔斷執行代碼
@Component
public class FallbackService implements GetAuthorService {
@Override
public String getAuthorInfo(String authorId) {
return "服務被熔斷"+authorId;
}
}3)、配置文件
?開啟熔斷功能
feign: hystrix: enabled: true
3、服務類注解
由于上面的接口和熔斷代碼是在不同的Jar模塊中,所以要在啟動類@SpringBootApplication注解中掃描,如下。
@SpringBootApplication(scanBasePackages = {"cloud.node02.consume","cloud.block.code.service"})
@EnableEurekaClient // 本服務啟動后會自動注冊進eureka服務中
@EnableDiscoveryClient
// 因為包名路徑不同,需要加basePackages屬性
@EnableFeignClients(basePackages={"cloud.block.code.service"})
public class Application_8002 {
public static void main(String[] args) {
SpringApplication.run(Application_8002.class,args) ;
}
}感謝你能夠認真閱讀完這篇文章,希望小編分享的“SpringCloud微服務之Hystrix組件如何實現服務熔斷”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。