.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 }
- ClientWhitelist:客戶端白名單,白名單不受限流規(guī)則限制。
- EnableRateLimiting:是否啟用限流。
- Period:周期,單位有s(秒)、m(分)、h(時)、d(天),比如1h
- PeriodTimespan:多少秒后重試。
- 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)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- ASP.NET Core為Ocelot網(wǎng)關(guān)配置Swagger
- ASP.NET?Core設(shè)置Ocelot網(wǎng)關(guān)限流
- ASP.NET?Core中的Ocelot網(wǎng)關(guān)介紹
- .Net?Core微服務(wù)網(wǎng)關(guān)Ocelot集成Consul
- .Net?Core微服務(wù)網(wǎng)關(guān)Ocelot基礎(chǔ)介紹及集成
- ASP.NET Core Api網(wǎng)關(guān)Ocelot的使用初探
- ASP.NET Core3.1 Ocelot負載均衡的實現(xiàn)
- ASP.NET Core3.1 Ocelot認證的實現(xiàn)
- ASP.NET Core3.1 Ocelot路由的實現(xiàn)
- Asp.Net?Core使用Ocelot結(jié)合Consul實現(xiàn)服務(wù)注冊和發(fā)現(xiàn)
相關(guān)文章
ASP.NET 2.0中的數(shù)據(jù)操作之八:使用兩個DropDownList過濾的主/從報表
本文主要介紹在ASP.NET 2.0中如何如何將DropDownList和另一個DropDownList控件關(guān)聯(lián),選擇產(chǎn)品分類和具體的產(chǎn)品時,使用DetailsView顯示產(chǎn)品的詳細信息。2016-05-05解讀ASP.NET 5 & MVC6系列教程(14):View Component
這篇文章主要介紹了ASP.NET 5 MVC6 中View Component創(chuàng)建和視圖的使用,需要的朋友可以參考下2016-06-06解讀ASP.NET 5 & MVC6系列教程(13):TagHelper
這篇文章主要介紹了新版MVC6中強大的TagHelper功能,需要的朋友可以參考下2016-06-06在ASP.NET 2.0中操作數(shù)據(jù)之三十九:在DataList的編輯界面里添加驗證控件
為了防止用戶非法的輸入,這節(jié)主要介紹如何在編輯數(shù)據(jù)的時候添加驗證控件,以避免出現(xiàn)異常和保證數(shù)據(jù)的完整性。2016-05-05在ASP.NET 2.0中操作數(shù)據(jù)之十八:在ASP.NET頁面中處理BLL/DAL層的異常
本文主要介紹ASP.NET 2.0中如何在頁面中處理BLL和DAL層的異常,程序演示了如何在頁面中顯示友好的異常信息,以及講解了如何在DAL層拋出自定義異常。2016-05-05在ASP.NET 2.0中操作數(shù)據(jù)之六:編程設(shè)置ObjectDataSource的參數(shù)值
本文主要介紹在ObjectDataSource控件的Selecting事件中,設(shè)置InputParameters參數(shù),配合業(yè)務(wù)層的查詢方法,以達到查詢不同數(shù)據(jù)的目的。2016-04-04在ASP.NET 2.0中操作數(shù)據(jù)之四:使用ObjectDataSource展現(xiàn)數(shù)據(jù)
前面介紹搭建基礎(chǔ)的架構(gòu),下面我們來介紹ASP.NET中,如何利用ObjectDataSource來展現(xiàn)數(shù)據(jù)。通過配置ObjectDataSource,我們指定這些底層的對象,還有這些對象的方法如何映射到ObjectDataSource的Select、Insert、Update和Delete方法。2016-04-04NopCommerce架構(gòu)分析之(六)自定義RazorViewEngine和WebViewPage
本文對NopCommerce的后臺分離技術(shù)做簡單的探討。NopCommerce通過自定義視圖引擎,重寫了VirtualPathProviderViewEngine類的CreateView、CreatePartialView、FindView、FindPartialView方法,添加自定義的視圖搜索路徑來實現(xiàn)后臺分離。2016-04-04在ASP.NET 2.0中操作數(shù)據(jù)之三十三:基于DataList和Repeater使用DropDownList過濾的主/
前面已經(jīng)介紹過使用DropDownList過濾的主/從報表,不過當時是基于GridView,本文算是復(fù)習一下,基于DataList和Repeater再次實現(xiàn)一下相同的功能。2016-05-05