日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

基于.NET CORE微服务框架 -谈谈surging的服务容错降级

發布時間:2023/12/4 asp.net 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 基于.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

最新地址: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策略直接本地模塊調用

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

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

1 [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網關正在著手研究,下個月應該會集成ocelot,如感興趣請多關注或者加入QQ群:615562965

相關文章

  • 谷歌發布的首款基于HTTP/2和protobuf的RPC框架:GRPC

  • 擁抱.NET Core,跨平臺的輕量級RPC:Rabbit.Rpc

  • 基于DotNet Core的RPC框架(一) DotBPE.RPC快速開始

  • 基于.NET CORE微服務框架 -surging的介紹和簡單示例 (開源)

原文地址:http://www.cnblogs.com/fanliang11/p/7224210.html


.NET社區新聞,深度好文,微信中搜索dotNET跨平臺或掃描二維碼關注

總結

以上是生活随笔為你收集整理的基于.NET CORE微服务框架 -谈谈surging的服务容错降级的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。