溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Sentinel中的熔斷策略有哪些

發(fā)布時(shí)間:2020-12-14 14:41:20 來(lái)源:億速云 閱讀:2518 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

Sentinel中的熔斷策略有哪些?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

熔斷策略

Sentinel 提供以下幾種熔斷策略:

慢調(diào)用比例 (SLOW_REQUEST_RATIO):選擇以慢調(diào)用比例作為閾值,需要設(shè)置允許的慢調(diào)用 RT(即最大的響應(yīng)時(shí)間),請(qǐng)求的響應(yīng)時(shí)間大于該值則統(tǒng)計(jì)為慢調(diào)用。當(dāng)單位統(tǒng)計(jì)時(shí)長(zhǎng)(statIntervalMs)內(nèi)請(qǐng)求數(shù)目大于設(shè)置的最小請(qǐng)求數(shù)目,并且慢調(diào)用的比例大于閾值,則接下來(lái)的熔斷時(shí)長(zhǎng)內(nèi)請(qǐng)求會(huì)自動(dòng)被熔斷。經(jīng)過(guò)熔斷時(shí)長(zhǎng)后熔斷器會(huì)進(jìn)入探測(cè)恢復(fù)狀態(tài)(HALF-OPEN 狀態(tài)),若接下來(lái)的一個(gè)請(qǐng)求響應(yīng)時(shí)間小于設(shè)置的慢調(diào)用 RT 則結(jié)束熔斷,若大于設(shè)置的慢調(diào)用 RT 則會(huì)再次被熔斷。
異常比例 (ERROR_RATIO):當(dāng)單位統(tǒng)計(jì)時(shí)長(zhǎng)(statIntervalMs)內(nèi)請(qǐng)求數(shù)目大于設(shè)置的最小請(qǐng)求數(shù)目,并且異常的比例大于閾值,則接下來(lái)的熔斷時(shí)長(zhǎng)內(nèi)請(qǐng)求會(huì)自動(dòng)被熔斷。經(jīng)過(guò)熔斷時(shí)長(zhǎng)后熔斷器會(huì)進(jìn)入探測(cè)恢復(fù)狀態(tài)(HALF-OPEN 狀態(tài)),若接下來(lái)的一個(gè)請(qǐng)求成功完成(沒(méi)有錯(cuò)誤)則結(jié)束熔斷,否則會(huì)再次被熔斷。異常比率的閾值范圍是 [0.0, 1.0],代表 0% - 100%。
異常數(shù) (ERROR_COUNT):當(dāng)單位統(tǒng)計(jì)時(shí)長(zhǎng)內(nèi)的異常數(shù)目超過(guò)閾值之后會(huì)自動(dòng)進(jìn)行熔斷。經(jīng)過(guò)熔斷時(shí)長(zhǎng)后熔斷器會(huì)進(jìn)入探測(cè)恢復(fù)狀態(tài)(HALF-OPEN 狀態(tài)),若接下來(lái)的一個(gè)請(qǐng)求成功完成(沒(méi)有錯(cuò)誤)則結(jié)束熔斷,否則會(huì)再次被熔斷、

Sentinel中的熔斷策略有哪些

慢調(diào)用比例:
最大 RT:200意思是 在200毫秒處理完這個(gè)請(qǐng)求
比例閥值:1 意思是是 在200毫秒處理一個(gè)請(qǐng)求 你設(shè)置幾就就200毫秒處理幾個(gè)

熔斷時(shí)長(zhǎng):1意思是一秒內(nèi)不可用
最小請(qǐng)求數(shù):5 意思是 一秒5次請(qǐng)求

Sentinel中的熔斷策略有哪些
Sentinel中的熔斷策略有哪些

異常比例:
比例閥值:官網(wǎng):(異常比率的閾值范圍是 [0.0, 1.0],代表 0% - 100%)0.3意思錯(cuò)誤的達(dá)到了百分之30的時(shí)候 觸發(fā)熔斷

熔斷時(shí)間:1的意思是一秒之間不可用
最小請(qǐng)求數(shù):5一秒5個(gè)

Sentinel中的熔斷策略有哪些

異常數(shù)
異常數(shù):3意思是超過(guò)3個(gè)異常,就是第4次進(jìn)入熔斷服務(wù)降級(jí),當(dāng)?shù)谖宕握?qǐng)求是對(duì)的就會(huì)恢復(fù)
熔斷時(shí)長(zhǎng):1秒

Sentinel中的熔斷策略有哪些

熱點(diǎn)參數(shù)限流
何為熱點(diǎn)?熱點(diǎn)即經(jīng)常訪問(wèn)的數(shù)據(jù)。很多時(shí)候我們希望統(tǒng)計(jì)某個(gè)熱點(diǎn)數(shù)據(jù)中訪問(wèn)頻次最高的 Top K 數(shù)據(jù),并對(duì)其訪問(wèn)進(jìn)行限制。比如:

商品 ID 為參數(shù),統(tǒng)計(jì)一段時(shí)間內(nèi)最常購(gòu)買(mǎi)的商品 ID 并進(jìn)行限制
用戶(hù) ID 為參數(shù),針對(duì)一段時(shí)間內(nèi)頻繁訪問(wèn)的用戶(hù) ID 進(jìn)行限制
熱點(diǎn)參數(shù)限流會(huì)統(tǒng)計(jì)傳入?yún)?shù)中的熱點(diǎn)參數(shù),并根據(jù)配置的限流閾值與模式,對(duì)包含熱點(diǎn)參數(shù)的資源調(diào)用進(jìn)行限流。熱點(diǎn)參數(shù)限流可以看做是一種特殊的流量控制,僅對(duì)包含熱點(diǎn)參數(shù)的資源調(diào)用生效。

Sentinel中的熔斷策略有哪些

示例:
這里有兩個(gè) 參數(shù)一個(gè)是A 一個(gè)是B熱點(diǎn)限流是根據(jù)設(shè)置參數(shù)的下標(biāo)設(shè)置的,下表是從0開(kāi)始的,
@SentinelResource注解設(shè)置要限流的id, blockHandler設(shè)置返回可預(yù)知的響應(yīng)體

 @GetMapping(value = "select/test")
 @SentinelResource(value = "test",blockHandler = "teat1")
 public String test(@RequestParam(value = "a",required = false) Integer a,@RequestParam(value = "b",required = false) Integer b){

 return "我是:Sentinel";

 }

設(shè)置的可預(yù)知的響應(yīng)體這個(gè)的BlockException是必須的參數(shù)

 public String teat1(@RequestParam(value = "a",required = false) Integer a,@RequestParam(value = "b",required = false)Integer b, BlockException e){

 return "沒(méi)錯(cuò)我就是我了";

 }

配置
test是@SentinelResource(value = "test",blockHandler = "teat1")
參數(shù)索引:0就是0下標(biāo)
單機(jī)閥值:1處理的個(gè)數(shù)
統(tǒng)計(jì)窗口時(shí)長(zhǎng) 1是一秒處理完成

Sentinel中的熔斷策略有哪些

高級(jí)選項(xiàng)

Sentinel中的熔斷策略有哪些

參數(shù)類(lèi)型:選擇參數(shù)的數(shù)據(jù)類(lèi)型
參數(shù)值:1就參數(shù)如果等于1就限流
限流閥: 3就是3次

Sentinel中的熔斷策略有哪些

這些可以自己測(cè)試

Sentinel中的熔斷策略有哪些

服務(wù)熔斷

Sentinel 提供了 @SentinelResource 注解用于定義資源,并提供了 AspectJ 的擴(kuò)展用于自動(dòng)定義資源、處理 BlockException 等。

@SentinelResource 注解

@SentinelResource 用于定義資源,并提供可選的異常處理和 fallback 配置項(xiàng)。 @SentinelResource 注解包含以下屬性:

value:資源名稱(chēng),必需項(xiàng)(不能為空)
entryType:entry 類(lèi)型,可選項(xiàng)(默認(rèn)為 EntryType.OUT)
blockHandler / blockHandlerClass: blockHandler 對(duì)應(yīng)處理 BlockException 的函數(shù)名稱(chēng),可選項(xiàng)。blockHandler 函數(shù)訪問(wèn)范圍需要是 public,返回類(lèi)型需要與原方法相匹配,參數(shù)類(lèi)型需要和原方法相匹配并且最后加一個(gè)額外的參數(shù),類(lèi)型為 BlockException。blockHandler 函數(shù)默認(rèn)需要和原方法在同一個(gè)類(lèi)中。若希望使用其他類(lèi)的函數(shù),則可以指定 blockHandlerClass 為對(duì)應(yīng)的類(lèi)的 Class 對(duì)象,注意對(duì)應(yīng)的函數(shù)必需為 static 函數(shù),否則無(wú)法解析。
fallback / fallbackClass:fallback 函數(shù)名稱(chēng),可選項(xiàng),用于在拋出異常的時(shí)候提供 fallback 處理邏輯。fallback 函數(shù)可以針對(duì)所有類(lèi)型的異常(除了 exceptionsToIgnore 里面排除掉的異常類(lèi)型)進(jìn)行處理。fallback 函數(shù)簽名和位置要求:
返回值類(lèi)型必須與原函數(shù)返回值類(lèi)型一致;
方法參數(shù)列表需要和原函數(shù)一致,或者可以額外多一個(gè) Throwable 類(lèi)型的參數(shù)用于接收對(duì)應(yīng)的異常。
fallback 函數(shù)默認(rèn)需要和原方法在同一個(gè)類(lèi)中。若希望使用其他類(lèi)的函數(shù),則可以指定 fallbackClass 為對(duì)應(yīng)的類(lèi)的 Class 對(duì)象,注意對(duì)應(yīng)的函數(shù)必需為 static 函數(shù),否則無(wú)法解析。
defaultFallback(since 1.6.0):默認(rèn)的 fallback 函數(shù)名稱(chēng),可選項(xiàng),通常用于通用的 fallback 邏輯(即可以用于很多服務(wù)或方法)。默認(rèn) fallback 函數(shù)可以針對(duì)所有類(lèi)型的異常(除了 exceptionsToIgnore 里面排除掉的異常類(lèi)型)進(jìn)行處理。若同時(shí)配置了 fallback 和 defaultFallback,則只有 fallback 會(huì)生效。defaultFallback 函數(shù)簽名要求:
返回值類(lèi)型必須與原函數(shù)返回值類(lèi)型一致;
方法參數(shù)列表需要為空,或者可以額外多一個(gè) Throwable 類(lèi)型的參數(shù)用于接收對(duì)應(yīng)的異常。
defaultFallback 函數(shù)默認(rèn)需要和原方法在同一個(gè)類(lèi)中。若希望使用其他類(lèi)的函數(shù),則可以指定 fallbackClass 為對(duì)應(yīng)的類(lèi)的 Class 對(duì)象,注意對(duì)應(yīng)的函數(shù)必需為 static 函數(shù),否則無(wú)法解析。
exceptionsToIgnore(since 1.6.0):用于指定哪些異常被排除掉,不會(huì)計(jì)入異常統(tǒng)計(jì)中,也不會(huì)進(jìn)入 fallback 邏輯中,而是會(huì)原樣拋出。
1.8.0 版本開(kāi)始,defaultFallback 支持在類(lèi)級(jí)別進(jìn)行配置。

注:1.6.0 之前的版本 fallback 函數(shù)只針對(duì)降級(jí)異常(DegradeException)進(jìn)行處理,不能針對(duì)業(yè)務(wù)異常進(jìn)行處理。

特別地,若 blockHandler 和 fallback 都進(jìn)行了配置,則被限流降級(jí)而拋出 BlockException 時(shí)只會(huì)進(jìn)入 blockHandler 處理邏輯。若未配置 blockHandler、fallback 和 defaultFallback,則被限流降級(jí)時(shí)會(huì)將 BlockException 直接拋出(若方法本身未定義 throws BlockException 則會(huì)被 JVM 包裝一層 UndeclaredThrowableException)。

示例:

1,fallback處理java異常

@SentinelResource(value = "select",fallback = "ErrorFallback")

代碼

 @GetMapping(value = "select/{id}")
 @SentinelResource(value = "select",fallback = "ErrorFallback")
 public CommonResult getid(@PathVariable Long id){

  if(id>3) {
  throw new NullPointerException(id+"沒(méi)有記錄");
  }else {
  return restTemplate.getForObject(URL + "/select/" + id, CommonResult.class);
  }

 }

fallback 處理方法

public CommonResult ErrorFallback(@PathVariable Long id,Throwable e){

 return new CommonResult<>(500,"不好意,沒(méi)有此記錄");
 }

處理結(jié)果

Sentinel中的熔斷策略有哪些

blockHandler 處理sentinel配置異常 java的異常無(wú)法處理

@SentinelResource(value = "select",blockHandler = "ErrorFallback")

 public CommonResult ErrorFallback(@PathVariable Long id, BlockException e){

 return new CommonResult<>(500,"不好意,沒(méi)有此記錄"+e.getMessage());
 }

測(cè)試
這設(shè)置的是異常比例 異常達(dá)到百分之30進(jìn)行熔斷

Sentinel中的熔斷策略有哪些
Sentinel中的熔斷策略有哪些

Sentinel中的熔斷策略有哪些

兩個(gè)注解同時(shí)用

 @SentinelResource(value = "select",blockHandler = "ErrorFallback",fallback = "ErrorFallback1")
public CommonResult ErrorFallback1(@PathVariable Long id, Throwable e){

 return new CommonResult<>(500,"fallback:不好意,沒(méi)有此記錄"+e.getMessage());
 }
 public CommonResult ErrorFallback(@PathVariable Long id, BlockException e){

 return new CommonResult<>(500,"blockHandler:不好意,沒(méi)有此記錄"+e.getMessage());
 }

Sentinel中的熔斷策略有哪些

Sentinel中的熔斷策略有哪些

但是 要是blockHandler 和fallback 同時(shí)配置則被限流降級(jí)拋出異常BlockException 處理

exceptionsToIgnore
 @SentinelResource(value = "select",blockHandler = "ErrorFallback",fallback = "ErrorFallback1"
   ,exceptionsToIgnore = {IllegalAccessException.class})
blockHandlerClass=定義返回統(tǒng)一返回方法.class

業(yè)務(wù)

@GetMapping(value = "select/test")
 @SentinelResource(value = "test",blockHandlerClass= MySentinel.class,blockHandler = "a")
 public String test(@RequestParam(value = "a",required = false) Integer a,@RequestParam(value = "b",required = false) Integer b){

 return "我是:Sentinel";

 }

熔斷降級(jí)

package com.tang.cloud.mysentinel;

import com.alibaba.csp.sentinel.slots.block.BlockException;
import jdk.nashorn.internal.ir.Block;
import org.bouncycastle.crypto.engines.BlowfishEngine;
import org.springframework.web.bind.annotation.RequestParam;

/**
 * 統(tǒng)一返回降級(jí)處理
 */
public class MySentinel {

 //返回的的類(lèi)型和調(diào)用的方法的類(lèi)型一致,參數(shù)的類(lèi)型和個(gè)數(shù)相同
 public static String a(@RequestParam(value = "a",required = false) Integer a, @RequestParam(value = "b",required = false) Integer b, BlockException excep){

 return "我在在另一個(gè)類(lèi)中定義的方法";
 }
 }

關(guān)于Sentinel中的熔斷策略有哪些問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI