基於.NET CORE微服務架構 -談談surging的服務容錯降級

來源:互聯網
上載者:User

標籤:seconds   http   內容   row   注入   requests   程式集   名稱   rate   

一、前言

對於不久開源的surging受到不少.net同學的青睞,也受到.net core學習小組的關注,邀請加入.NET China Foundation 以方便國內.net core開源項目的推廣,我果斷接受邀請加入了隊伍進行互相交流學習,最近也更新了surging新的版本

更新內容:

1. Castle.Core 相容性問題,下一版本會去除,解決部分使用者第一次編譯VS卡死問題
2. 增加容錯降級
3. 路由容錯重構,針對於失敗重試和失敗沒有重試,失敗回調,
4.增加部分功能單元測試
5. 升級支援.NET CORE 2.0

最新地址:https://github.com/dotnetcore/surging

二、服務容錯降級介紹和樣本1.服務容錯降級介紹

對於上篇文章所提到的微服務可靠性,對於容錯和降級省略沒講,這篇介紹下容錯和降級

 

當微服務不可用時,需要根據預置的策略做容錯處理,大部分的容錯能力和策略是公用的,因此可以放到架構中實現。

服務容錯

當微服務調用失敗之後,利用容錯機制,可以在底層實現微服務的自動容錯處理,提升系統的可靠性。

 surging容錯策略包括:

 失敗自動切換機制(Failover):微服務調用失敗自動切換策略指的是當發生服務調用異常時,重新選路,尋找下一個可用的微    服務提供者。微服務發布的時候,可以指定服務的叢集容錯策略。消費者可以覆蓋服務提供者的通用配置,實現個人化的容錯策略。

 失敗回調機制(Injection):微服務調用失敗之後,提供異常回調介面或者注入指令碼,執行微服務消費者自訂的失敗處理邏輯。

服務降級

服務因為某種原因不可用,但是流程不能直接失敗,需要本地Injection服務端實現,比如年底購票12306大規模的訪問,導致查詢火車票服務不能正常工作,這時候要做業務放通,返回上次的緩衝記錄或者NULL,而不是返回失敗。

降級的常用策略:

 1、服務路由短路,直接返回空。例如Injection = “ return null;”。

 3、服務路由短路,直接執行本地類比介面實作類別。Injection = “ true;”。

容錯降級

當服務不可用時,可以服務做商務邏輯放通,讓服務正常運行

自動容錯降級:是根據定義的闞值自動匹配觸發,調用相關的策略進行降級。

強制降級:由營運根據系統運行情況手工操作觸發的。

2.服務容錯降級樣本

建立服務容錯降級,選擇Injection策略指令碼注入,直接返回null

[Command(Strategy= StrategyType.Injection ,Injection = @"return null;")]

建立服務容錯降級,選擇Injection策略指令碼注入,直接返回Task<UserModel>

[Command(Strategy= StrategyType.Injection ,Injection = @"return Task.FromResult(new Surging.IModuleServices.Common.Models.UserModel         {            Name=""fanly"",            Age=18         });",InjectionNamespaces =new string[] { "Surging.IModuleServices.Common"})] 

建立服務容錯降級,選擇Injection策略直接本地模組調用

[Command(Strategy= StrategyType.Injection ,Injection = @"return true;")] 

 建立服務容錯降級,選擇Failover策略,自動切換重試遠程調用

 [Command(Strategy= StrategyType.Failover )] 

 配置相關參數列表

參數 作用 備忘

Strategy

容錯策略

包括Failover和Injection

FailoverCluster

 容錯移轉次數 預設值:3

ExecutionTimeoutInMilliseconds

執行逾時時間 預設值:1000
RequestCacheEnabled 是否開啟緩衝 預設關閉

Injection

指令碼注入  

InjectionNamespaces

注入命名空間 稱為程式集名稱更恰當

BreakeErrorThresholdPercentage

錯誤率達到多少開啟熔斷保護 預設值:50
BreakeSleepWindowInMilliseconds 熔斷多少秒後去嘗試請求 預設值:60000
BreakerForceClosed 是否強制關閉熔斷  

BreakerRequestVolumeThreshold

10秒鐘內至少多少請求失敗,熔斷器才發揮起作用 預設值:20

MaxConcurrentRequests

最大並發數 10
三.測試

測試環境

CPU:Intel Core i7-4710MQ

記憶體:16G

硬碟:1T SSD+512G HDD

網路:區域網路

測試結果如下:

三、總結

surging下一版本增加緩衝降級、針對檔案進行佈建服務容錯,降級等內容,添加單元測試,對於API Gateway正在著手研發,如感興趣請多關注或者加入QQ群:615562965

 

基於.NET CORE微服務架構 -談談surging的服務容錯降級

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.