Spring Cloud Alibaba 的學習之熔斷篇


什么是服務雪崩

在微服務架構中,根據業務來拆分成一個個的服務,服務與服務之間可以通過 HTTP/RPC 相互調用,在 Spring Cloud 中可以用 RestTemplate + LoadBalanceClient 和 Feign 來調用。為了保證其高可用,單個服務通常會集群部署。由於網絡原因或者自身的原因,服務並不能保證 100% 可用,如果單個服務出現問題,調用這個服務就會出現線程阻塞,此時若有大量的請求涌入,Servlet 容器的線程資源會被消耗完畢,導致服務癱瘓。服務與服務之間的依賴性,故障會傳播,會對整個微服務系統造成災難性的嚴重后果,這就是服務故障的 “雪崩” 效應。為了解決這個問題,業界提出了 熔斷器模型。

Sentinel

阿里巴巴開源了 Sentinel 組件,實現了熔斷器模式,Spring Cloud 對這一組件進行了整合。在微服務架構中,一個請求需要調用多個服務是非常常見的。較底層的服務如果出現故障,會導致連鎖故障。當對特定的服務的調用的不可用達到一個閥值熔斷器將會被打開,熔斷器打開后,為了避免連鎖故障,通過 fallback 方法可以直接返回一個固定值。

Sentinel 的特征

  • 豐富的應用場景: Sentinel 承接了阿里巴巴近 10 年的雙十一大促流量的核心場景,例如秒殺(即突發流量控制在系統容量可以承受的范圍)、消息削峰填谷(對於突然到來的大量請求,您可以配置流控規則,以穩定的速度逐步處理這些請求,從而避免流量突刺造成系統負載過高)、集群流量控制、實時熔斷下游不可用應用等
  • 完備的實時監控: Sentinel 同時提供實時的監控功能。您可以在控制台中看到接入應用的單台機器秒級數據,甚至 500 台以下規模的集群的匯總運行情況
  • 廣泛的開源生態: Sentinel 提供開箱即用的與其它開源框架 / 庫的整合模塊,例如與 Spring Cloud、Dubbo、gRPC 的整合。您只需要引入相應的依賴並進行簡單的配置即可快速地接入 Sentinel
  • 完善的 SPI 擴展點: Sentinel 提供簡單易用、完善的 SPI 擴展接口。您可以通過實現擴展接口來快速地定制邏輯。例如定制規則管理、適配動態數據源等

Sentinel控制台

從官方 GitHub Release 頁面 頁面下載最新版本的控制台 JAR 包。

啟動

注意: 啟動 Sentinel 控制台需要 JDK 版本為 1.8 及以上版本

java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard-1.6.3.jar

其中 -Dserver.port=8080 用於指定 Sentinel 控制台端口為 8080

注意: 從 Sentinel 1.6.0 起,Sentinel 控制台引入基本的 登錄 功能,默認用戶名和密碼都是 sentinel

鑒權

用戶可以通過如下參數進行配置

-Dsentinel.dashboard.auth.username=sentinel 用於指定控制台的登錄用戶名為 sentinel
-Dsentinel.dashboard.auth.password=123456 用於指定控制台的登錄密碼為 123456;如果省略這兩個參數,默認用戶和密碼均為 sentinel
-Dserver.servlet.session.timeout=7200 用於指定 Spring Boot 服務端 session 的過期時間,如 7200 表示 7200 秒;60m 表示 60 分鍾,默認為 30 分鍾
驗證安裝是否成功

通過瀏覽器訪問 http://localhost:8080/#/login
賬號: sentinel
密碼: sentinel

客戶端接入

POM:

        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
        </dependency>

YML:

spring:
 application:
   name: consumer-reset

 cloud:
   nacos:
     discovery:
       server-addr: 192.168.233.150:8848
       # 熔斷限流
   sentinel:
     transport:
       dashboard: localhost:8888
#開啟 Feign 對 Sentinel 的支持
feign:
 sentinel:
   enabled: true
server:
 port: 12000

management:
 endpoints:
   web:
     exposure:
       include: "*"
       

配置熔斷類

編寫一個 Feign 接口的實現類並增加 @Component 注解

@Component
public class ResetServiceFallback implements ResetService {
    @Override
    public List initPuzzle() {
        return Arrays.asList("500");
    }
}

修改 Feign 接口

在 @FeignClient 接口上增加 fallback 屬性指定熔斷類即可

@FeignClient(value = "puzzle-provider",fallback = ResetServiceFallback.class)
public interface ResetService {
    @GetMapping(value = "init")
    List initPuzzle();
}

測試熔斷

啟動 consumer-reset服務並停止 puzzle-provider 服務,通過瀏覽器訪問http://localhost:12000/reset


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM