欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

.Net?Core微服務(wù)網(wǎng)關(guān)Ocelot超時、熔斷、限流

 更新時間:2022年01月06日 08:44:29   作者:老馬-Max  
這篇文章介紹了.Net?Core微服務(wù)網(wǎng)關(guān)Ocelot超時、熔斷、限流,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

基本概念

超時、熔斷、限流聽起來好像很遠,但實際上用在方方面面。很多人可能還搞不懂熔斷是做什么,其實可以把熔斷理解為一種防護措施。做個假設(shè),在微服務(wù)體系下,某個下游服務(wù)響應(yīng)很慢,然后隨著時間推移,會有越來越多的請求堆積,從而會導(dǎo)致各種嚴重后果,單說連接池大量被占用就很要命。更不用說服務(wù)之間還要相互調(diào)用,你等我10秒,我等你5秒,不僅毫無體驗感,高可用也就成了空談。不如換個思路:與其等10秒返回一個請求失敗,不如馬上就返回請求失敗。這樣一來,請求堆不起來,資源也有時間釋放或者恢復(fù)。這個動作就叫熔斷,或者叫短路。有點像家用電路,一旦有漏電直接跳閘,最大程度保障安全。

熔斷的概念基本有了,接下來給網(wǎng)關(guān)集成。這里需要用到一個叫polly的庫。

簡單說下它:polly由.net實現(xiàn),是一個非常優(yōu)秀的庫,主要提供重試、熔斷、超時、恢復(fù)等功能,當然今天主角不是它,想研究的可以去官方看下:https://github.com/App-vNext/Polly

接下來開始集成。首先添加nuget包:

然后注冊相關(guān)服務(wù):

public void ConfigureServices(IServiceCollection services)
        {
            services.AddOcelot()
                .AddPolly()
                .AddConsul()
                .AddConfigStoredInConsul();
        }

接下來在配置文件添加節(jié)點:

"QoSOptions": {
    "ExceptionsAllowedBeforeBreaking":3,
    "DurationOfBreak":10000,
    "TimeoutValue":5000
}
  • ExceptionsAllowedBeforeBreaking:閾值,當轉(zhuǎn)發(fā)到下游的服務(wù)連續(xù)出現(xiàn)的異常次數(shù)達到閾值就會觸發(fā)熔斷。必須和DurationOfBreak一起設(shè)置。
  • DurationOfBreak:熔斷持續(xù)時間,單位毫秒。必須和ExceptionsAllowedBeforeBreaking一起設(shè)置。
  • TimeoutValue:限定時間內(nèi)未響應(yīng)的請求直接超時,單位毫秒??梢詥为氃O(shè)置
  • tips:ocelot默認超時時間是90秒,90秒啊

然后寫一個方法,休眠10秒:

[HttpGet]
        public IActionResult TimeOut()
        {
            System.Threading.Thread.Sleep(10000);
            return Ok();
        }

超時

準備工作做完了,現(xiàn)在調(diào)用timeout方法:

方法是休眠10秒,但是等待5秒左右就主動返回了503,說明超時的設(shè)置已經(jīng)生效。

熔斷

當轉(zhuǎn)發(fā)到下游某個服務(wù)的請求連續(xù)出現(xiàn)超時情況時,網(wǎng)關(guān)就會判斷是否達到閾值,如果是就觸發(fā)熔斷,在此期間的請求統(tǒng)一返回503,熔斷時間過了以后恢復(fù)正常。按上面配置來看:連續(xù)超時3次會觸發(fā)熔斷,熔斷持續(xù)10秒。我們?nèi)匀徽{(diào)用Timeout方法,連續(xù)3次以后:

沒有觸發(fā)熔斷時,只能等過5秒自動超時,很顯然現(xiàn)在已經(jīng)觸發(fā)了超時,所以在200毫秒就直接返回了結(jié)果。熔斷期間訪問別的方法也會是503:

和開頭寫的一樣,熔斷和電路短路跳閘是思路是一樣的,就算家里N條線只有1條漏電,那還是會跳閘整個屋子不能用電,這種做法最大程度上保證了程序安全。

限流

假設(shè)現(xiàn)在只能承載1萬并發(fā),那么過來5萬并發(fā)會怎么樣?一般情況下,只要持續(xù)時間稍久一些,服務(wù)基本全都掛了。這種情況在生產(chǎn)環(huán)境難免會發(fā)生,畢竟業(yè)務(wù)量也無法測算那么精準。所以為了提高可用性,瞬時請求超過最大閾值,其他的全都忽略才能保證服務(wù)安全可用。讓客戶等下一次請求,總好過服務(wù)掛了沒的請求。

限流也是配置就能實現(xiàn),在路由中新增下面的節(jié)點:

"RateLimitOptions": {
    "ClientWhitelist": [],
    "EnableRateLimiting": true,
    "Period": "1s",
    "PeriodTimespan": 1,
    "Limit": 1
}
  1. ClientWhitelist:客戶端白名單,白名單不受限流規(guī)則限制。
  2. EnableRateLimiting:是否啟用限流。
  3. Period:周期,單位有s(秒)、m(分)、h(時)、d(天),比如1h
  4. PeriodTimespan:多少秒后重試。
  5. Limit:周期內(nèi)允許多少個請求。

想要更精細的控制,還可以在Global部分添加這些:

"RateLimitOptions": {
  "DisableRateLimitHeaders": false,
  "QuotaExceededMessage": "Customize Tips!",
  "HttpStatusCode": 999,
  "ClientIdHeader" : "Test"
}
  • DisableRateLimitHeaders:是否禁用X-Rate-Limit、Retry-After標頭。
  • QuotaExceededMessage:觸發(fā)限流時返回的消息。
  • HttpStatusCode:觸發(fā)限流時返回的http狀態(tài)碼(一般會寫429)。
  • ClientIdHeader:用來識別客戶端的標頭。
  • tips:DisableRateLimitHeaders中提到的X-Rate-Limit、Retry-After:X-Rate-Limit——標準時間內(nèi)允許多少個請求,Retry-After——觸發(fā)限流以后多久可以重試。

接下來修改我的配置:

"RateLimitOptions": {
        "ClientWhitelist": [ "myclient" ],
        "EnableRateLimiting": true,
        "Period": "1s",
        "PeriodTimespan": 10,
        "Limit": 1
      }

修改全局配置:

"RateLimitOptions": {
      "DisableRateLimitHeaders": false,
      "QuotaExceededMessage": "123123",
      "HttpStatusCode": 429,
      "ClientIdHeader": "Test"
    }

按配置來看,我設(shè)置1秒內(nèi)最多允許1個請求,超過就觸發(fā)限流。之后的請求都會返回429和123123,持續(xù)10秒。來試試:

等待10秒后再次請求,恢復(fù)正常:

白名單

白名單里的客戶端是不會受到限流限制的。按照配置添加請求頭,就可以被白名單識別:

請求時添加這個請求頭,無論怎么刷都不會被限流。

超時、熔斷、限流的必要性和好處是不言而喻的,但是上生產(chǎn)一定要注意配置的合理性,充分綜合業(yè)務(wù)場景和需要才是王道,畢竟技術(shù)如果不解決問題那就毫無意義。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論