激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - Java教程 - Sentinel熱點(diǎn)規(guī)則示例詳解分析

Sentinel熱點(diǎn)規(guī)則示例詳解分析

2021-12-13 13:20潮汐先生 Java教程

這篇文章主要介紹了何為熱點(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)行限制
  • 用戶 ID 為參數(shù),針對(duì)一段時(shí)間內(nèi)頻繁訪問(wèn)的用戶 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 利用 LRU 策略統(tǒng)計(jì)最近最常訪問(wèn)的熱點(diǎn)參數(shù),結(jié)合令牌桶算法來(lái)進(jìn)行參數(shù)級(jí)別的流控。

使用熱單參數(shù)限流式不能使用資源路徑,必須要使用資源名的方式。

Sentinel提供了@SentinelResource 注解用于定義資源

 

@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ú)法解析。
  • fallbac/fallbackClass:fallback 函數(shù)名稱(chēng),可選項(xiàng),用于在拋出異常的時(shí)候提供 fallback 處理邏輯。fallback 函數(shù)可以針對(duì)所有類(lèi)型的異常(除了exceptionsToIgnore里面排除掉的異常類(lèi)型)進(jìn)行處理。fallback 函數(shù)簽名和位置要求:

1.返回值類(lèi)型必須與原函數(shù)返回值類(lèi)型一致;
2.方法參數(shù)列表需要和原函數(shù)一致,或者可以額外多一個(gè) Throwable 類(lèi)型的參數(shù)用于接收對(duì)應(yīng)的異常。

3.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ù)簽名要求:

1.返回值類(lèi)型必須與原函數(shù)返回值類(lèi)型一致;

2.方法參數(shù)列表需要為空,或者可以額外多一個(gè) Throwable 類(lèi)型的參數(shù)用于接收對(duì)應(yīng)的異常。

3.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ì)原樣拋出。

注意:注解方式埋點(diǎn)不支持 private 方法特別地,若 blockHandler 和 fallback 都進(jìn)行了配置,

則被限流降級(jí)而拋出 BlockException 時(shí)只會(huì)進(jìn)入 blockHandler 處理邏輯。

若未配置 blockHandler、fallback 和 defaultFallback,

則被限流降級(jí)時(shí)會(huì)將 BlockException 直接拋出

(若方法本身未定義 throws BlockException 則會(huì)被 JVM 包裝一層 UndeclaredThrowableException)。

 

小試牛刀

TestController.java

我們將之前的TestController中的/test/hello方法做以下處理:

import com.alibaba.csp.sentinel.annotation.SentinelResource;
import com.alibaba.csp.sentinel.slots.block.BlockException;
import com.alibaba.csp.sentinel.slots.block.degrade.DegradeException;
import com.alibaba.csp.sentinel.slots.block.flow.FlowException;
import com.alibaba.csp.sentinel.slots.block.flow.param.ParamFlowException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* @Author Christy
* @Date 2021/8/6 10:17
**/
@RestController
@RequestMapping("/test")
public class TestController {
  private static final Logger log = LoggerFactory.getLogger(TestController.class);
  /**
   * @SentinelResource: 代表這是一個(gè)sentinel資源
   * value: 資源名稱(chēng)
   * blockHandler: 使用sentinel進(jìn)行不同規(guī)則控制時(shí)的默認(rèn)處理方案
   * fallback: 自定義業(yè)務(wù)出錯(cuò)時(shí)默認(rèn)處理方案
   * defaultFallback: 業(yè)務(wù)錯(cuò)誤時(shí)的默認(rèn)處理方案
   */
  @RequestMapping("/hello")
  @SentinelResource(value = "hello",blockHandler = "blockHandler",fallback = "fallback",defaultFallback = "defaultFallback")
  public String sayHello(Integer id){
      log.info("Hello, Sentinel!");
      if(id < 0){
          throw new RuntimeException();
      }
      return "Hello, Sentinel!";
  }
  public String blockHandler(Integer id, BlockException e){
      if(e instanceof FlowException){
          return  "當(dāng)前請(qǐng)求被流控!";
      }
      if(e instanceof DegradeException){
          return  "當(dāng)前請(qǐng)求被降級(jí)!";
      }
      if(e instanceof ParamFlowException){
          return  "當(dāng)前請(qǐng)求被熱點(diǎn)參數(shù)限流!";
      }
      return "當(dāng)前訪問(wèn)人數(shù)太多,請(qǐng)稍后再試!";
  }
  public String fallback(Integer id){
      return "fallback函數(shù)處理的異常!";
  }
 public String defaultFallback(){
      return "默認(rèn)的fallback函數(shù)處理的異常!";
  }
  @RequestMapping("/bye")
  public String sayBye(){
      log.info("Bye, Sentinel!");
      return "Bye, Sentinel!";
  }
}

defaultFallback

首先我們來(lái)試下沒(méi)有自定義fallback的情況,我們將TestControler中的/test/hello修改如下:

@RequestMapping("/hello")
@SentinelResource(value = "hello",blockHandler = "blockHandler",defaultFallback = "defaultFallback")
public String sayHello(Integer id){
log.info("Hello, Sentinel!");
if(id < 0){
  throw new RuntimeException();
}
return "Hello, Sentinel!";
}

然后我們啟動(dòng)項(xiàng)目,在瀏覽器中訪問(wèn)http://localhost:8990/test/hello?id=-1,

界面會(huì)返回默認(rèn)的fallback函數(shù)處理的異常!如下圖所示:

Sentinel熱點(diǎn)規(guī)則示例詳解分析

fallback

同樣的方式我們將TestControler中的/test/hello修改如下

@RequestMapping("/hello")
@SentinelResource(value = "hello",blockHandler = "blockHandler",fallback = "fallback",defaultFallback = "defaultFallback")
public String sayHello(Integer id){
log.info("Hello, Sentinel!");
if(id < 0){
  throw new RuntimeException();
}
return "Hello, Sentinel!";
}

我們?cè)俅螁?dòng)項(xiàng)目,在瀏覽器中訪問(wèn)http://localhost:8990/test/hello?id=-1,

界面會(huì)返回默認(rèn)的fallback函數(shù)處理的異常!

如下圖所示:

Sentinel熱點(diǎn)規(guī)則示例詳解分析

流量控制

我們?cè)赟entinel中的流控規(guī)則中新增一個(gè)規(guī)則,

如下所示:

Sentinel熱點(diǎn)規(guī)則示例詳解分析

然后我們?cè)跒g覽器中訪問(wèn)http://localhost:8990/test/hello,

發(fā)現(xiàn)結(jié)果被流控

Sentinel熱點(diǎn)規(guī)則示例詳解分析

熔斷降級(jí)

我們刪除上面的流控規(guī)則,按照下圖所示新增一個(gè)熔斷規(guī)則,

如圖所示:

Sentinel熱點(diǎn)規(guī)則示例詳解分析

然后我們?cè)跒g覽器中訪問(wèn)http://localhost:8990/test/hello?id=-1,

發(fā)現(xiàn)結(jié)果被降級(jí)

Sentinel熱點(diǎn)規(guī)則示例詳解分析

熱點(diǎn)參數(shù)限流

同樣的我們刪除上面的熔斷規(guī)則,按照下圖所示新增一個(gè)熱點(diǎn)參數(shù)規(guī)則。

如圖所示:

Sentinel熱點(diǎn)規(guī)則示例詳解分析

然后我們?cè)跒g覽器中訪問(wèn)http://localhost:8990/test/hello?id=-1

發(fā)現(xiàn)結(jié)果被熱點(diǎn)參數(shù)限流

Sentinel熱點(diǎn)規(guī)則示例詳解分析

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

在熱點(diǎn)規(guī)則的底部有高級(jí)選項(xiàng)功能,點(diǎn)開(kāi)它如下圖所示:

Sentinel熱點(diǎn)規(guī)則示例詳解分析

  • 參數(shù)類(lèi)型:是上述參數(shù)索引對(duì)應(yīng)參數(shù)的類(lèi)型。比如我們?cè)L問(wèn):http://localhost:8990/test/hello?id=?值得就是id的類(lèi)型
  • 參數(shù)值:我們上面寫(xiě)的是2,意思是只對(duì)id=2這個(gè)進(jìn)行熱點(diǎn)參數(shù)限流,其余的放過(guò);
  • 限流閾值:在統(tǒng)計(jì)時(shí)長(zhǎng)內(nèi)超過(guò)設(shè)定的閾值就會(huì)被限流

我們?cè)跒g覽器訪問(wèn)http://localhost:8990/test/hello?id=1可以發(fā)現(xiàn)是沒(méi)有問(wèn)題的,沒(méi)有被限流。

但是當(dāng)訪問(wèn)http://localhost:8990/test/hello?id=2時(shí)就會(huì)被限流。

如圖所示

Sentinel熱點(diǎn)規(guī)則示例詳解分析

熱點(diǎn)限流的高級(jí)選項(xiàng)中可以添加多個(gè)參數(shù)例外項(xiàng)

以上就是Sentinel熱點(diǎn)規(guī)則示例詳解分析的詳細(xì)內(nèi)容,更多關(guān)于Sentinel熱點(diǎn)規(guī)則的資料請(qǐng)關(guān)注服務(wù)器之家其它相關(guān)文章!

原文鏈接:https://blog.csdn.net/bbxylqf126com/article/details/119906245

延伸 · 閱讀

精彩推薦
  • Java教程Java BufferWriter寫(xiě)文件寫(xiě)不進(jìn)去或缺失數(shù)據(jù)的解決

    Java BufferWriter寫(xiě)文件寫(xiě)不進(jìn)去或缺失數(shù)據(jù)的解決

    這篇文章主要介紹了Java BufferWriter寫(xiě)文件寫(xiě)不進(jìn)去或缺失數(shù)據(jù)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望...

    spcoder14552021-10-18
  • Java教程升級(jí)IDEA后Lombok不能使用的解決方法

    升級(jí)IDEA后Lombok不能使用的解決方法

    最近看到提示IDEA提示升級(jí),尋思已經(jīng)有好久沒(méi)有升過(guò)級(jí)了。升級(jí)完畢重啟之后,突然發(fā)現(xiàn)好多錯(cuò)誤,本文就來(lái)介紹一下如何解決,感興趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java實(shí)現(xiàn)搶紅包功能

    Java實(shí)現(xiàn)搶紅包功能

    這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)搶紅包功能,采用多線程模擬多人同時(shí)搶紅包,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙...

    littleschemer13532021-05-16
  • Java教程小米推送Java代碼

    小米推送Java代碼

    今天小編就為大家分享一篇關(guān)于小米推送Java代碼,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧...

    富貴穩(wěn)中求8032021-07-12
  • Java教程20個(gè)非常實(shí)用的Java程序代碼片段

    20個(gè)非常實(shí)用的Java程序代碼片段

    這篇文章主要為大家分享了20個(gè)非常實(shí)用的Java程序片段,對(duì)java開(kāi)發(fā)項(xiàng)目有所幫助,感興趣的小伙伴們可以參考一下 ...

    lijiao5352020-04-06
  • Java教程Java8中Stream使用的一個(gè)注意事項(xiàng)

    Java8中Stream使用的一個(gè)注意事項(xiàng)

    最近在工作中發(fā)現(xiàn)了對(duì)于集合操作轉(zhuǎn)換的神器,java8新特性 stream,但在使用中遇到了一個(gè)非常重要的注意點(diǎn),所以這篇文章主要給大家介紹了關(guān)于Java8中S...

    阿杜7482021-02-04
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    這篇文章主要介紹了Java使用SAX解析xml的示例,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程xml與Java對(duì)象的轉(zhuǎn)換詳解

    xml與Java對(duì)象的轉(zhuǎn)換詳解

    這篇文章主要介紹了xml與Java對(duì)象的轉(zhuǎn)換詳解的相關(guān)資料,需要的朋友可以參考下...

    Java教程網(wǎng)2942020-09-17
主站蜘蛛池模板: a免费视频 | 欧美片a| 九九热视频在线 | 黄色高清免费 | 草b视频在线观看 | 欧美国产精品一区二区 | 久久国产成人午夜av浪潮 | 超碰人人射| 深夜福利视频免费观看 | 国产精品久久久久久久亚洲按摩 | 色99999| 国产精品高潮视频 | 中文字幕 亚洲一区 | 亚洲欧美不卡视频 | www.国产免费| 成人aaaaa片毛片按摩 | 国产日韩三区 | 欧美一级网 | 久久精品亚洲成在人线av网址 | 202z中文字幕第一页 | 日韩在线观看高清 | 精品国产91久久久久久久 | 午夜精品视频免费观看 | 国产做爰 | www.guochanav.com | 草久在线| 性欧美xxxx极品摘花 | 久久精精品 | 国产一级做a爰片在线看 | 91嫩草丨国产丨精品入口 | 久久久久久久久久网站 | 毛片免费视频观看 | 欧洲成人综合网 | 99精品视频在线观看免费播放 | 欧美黄成人免费网站大全 | 97porn| 国产免费最爽的乱淫视频a 午夜精品久久久久久久99热浪潮 | 激情网站免费观看 | 毛片在线视频免费观看 | 在线播放免费视频 | 久久最新视频 |