天天看點

SpringCloud微服務(03):Hystrix元件,實作服務熔斷一、熔斷器簡介二、基于Ribbon服務熔斷三、基于Feign服務熔斷四、源代碼說明

本文源碼: GitHub·點這裡 || GitEE·點這裡

一、熔斷器簡介

微服務架構特點就是多服務,多資料源,支撐系統應用。這樣導緻微服務之間存在依賴關系。如果其中一個服務故障,可能導緻系統當機,這就是所謂的雪崩效應。

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           

二、基于Ribbon服務熔斷

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

三、基于Feign服務熔斷

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) ;
    }
}           

四、源代碼說明

GitHub位址:知了一笑
https://github.com/cicadasmile/spring-cloud-base
碼雲位址:知了一笑
https://gitee.com/cicadasmile/spring-cloud-base