當前位置:
首頁 > 知識 > 基於.NET CORE微服務框架-談談surging的服務容錯降級

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


一、前言

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

更新內容:

1. Castle.Core 兼容性問題,下一版本會去除,解決部分用戶第一次編譯VS卡死問題

2. 增加容錯降級

3. 路由容錯重構,針對於失敗重試和失敗沒有重試,失敗回調,

4.增加部分功能單元測試

5. 升級支持.NET CORE 2.0


二、服務容錯降級介紹和示例

1.服務容錯降級介紹

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

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

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

服務容錯

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

surging容錯策略包括:

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

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

服務降級

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

降級的常用策略:

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

3、服務路由短路,直接執行本地模擬介面實現類。Injection = 「 true;」。

容錯降級

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

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

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

2.服務容錯降級示例

創建服務容錯降級,選擇Injection策略腳本注入,直接返回null

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

創建服務容錯降級,選擇Injection策略腳本注入,直接返回Task<UserModel>

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

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

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

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

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

配置相關參數列表

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


三.測試

測試環境

CPU:Intel Core i7-4710MQ

內存:16G

硬碟:1T SSD+512G HDD

網路:區域網

測試結果如下:

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

三、總結

surging下一版本增加緩存降級、針對文件進行配置服務容錯,降級等內容,添加單元測試,對於API網關正在著手研究,下個月應該會集成ocelot。

文章來自博客園


「勤工儉學計劃」,給你一個真正0元學習IT技術的機會!

http://www.ujiuye.com/zt/qgjx/?wt.bd=fq37300j

找工作太難?不是你不行,我們來幫你!

http://www.ujiuye.com/zt/jyfc/?wt.bd=fq37300j

交流群:345648424

喜歡這篇文章嗎?立刻分享出去讓更多人知道吧!

本站內容充實豐富,博大精深,小編精選每日熱門資訊,隨時更新,點擊「搶先收到最新資訊」瀏覽吧!


請您繼續閱讀更多來自 IT優就業 的精彩文章:

乾貨:基於 Git Flow 的 Git 最佳實踐
es6的一些基本語法
SpringMVC項目國際化(i18n)實現方法
實時地播放動畫的五維光場

TAG:IT優就業 |

您可能感興趣

談談ASP.NET Core中的ResponseCaching
談談.NET Core中基於Generic Host來實現後台任務
談談微服務架構中的基礎設施:Service Mesh與Istio
從CVPR 18談談華人研究者的Leadership
深入談談String.intern在JVM的實現
談談對Linux的Huge Pages與Transparent Huge Pages的認識
談談SimCloud的架構
旗艦再升級,談談華為新款MateBook X Pro
談談對GS和Spring Drive的看法
談談 Oracle Exadata 帶來的業務價值及優勢
談談關於NVMe和NVMe-oF的那些事
陷入多重「抄襲」!ZARA這次要和GUUCI、BALENCIAGA、REEBOK去談談?
談談MicroLED和ULED XD顯示面板技術 [農步祥]
int 和 Integer 有什麼區別?談談 Integer 的值緩存範圍
從iPhoneXR換成華為P30pro一星期,談談它的優缺點
AppleWatchSeries 3上手,我來談談優缺點!
體驗Anker Soundcore Flare,談談藍牙音箱能有哪些新玩法
iPhone8plus換上華為P30pro,談談真實使用感受
談談RedHat Forum 2018雲轉型技術亮點
談談常見的幾種CFD演算法-FVM FDM FEM MPS SPH LBM究竟有什麼區別