基於.NET CORE微服務框架 -談談Cache中間件和緩存降級

来源:http://www.cnblogs.com/fanliang11/archive/2017/07/29/7256069.html
-Advertisement-
Play Games

1、前言 surging受到不少.net同學的青睞,也提了不少問題,提的最多的是什麼時候集成API 網關,在這裡回答大家最近已經開始著手研發,應該在1,2個月內會有個初版API網關,其它像Token身份驗證,限流降級等功能完成時間會往後推 最近也更新了surging新的版本 更新內容: 1. Cac ...


1、前言

surging受到不少.net同學的青睞,也提了不少問題,提的最多的是什麼時候集成API 網關,在這裡回答大家最近已經開始著手研發,應該在1,2個月內會有個初版API網關,其它像Token身份驗證,限流降級等功能完成時間會往後推

最近也更新了surging新的版本

更新內容:

1. Cache中間件基於Redis 所依賴的第三方庫已將servicestack.redis轉成stackexchange
2. 增加緩存降級
3. 增加攔截緩存降級的例子

開源地址:https://github.com/dotnetcore/surging

2.軟體環境

IDE:Visual Studio 2017 15.3 Preview ,vscode
框架:.NET core 2.0

vscode 技術支持:

周松柏(zsbfre)

3、Cache中間件的使用

  在剝析surging的架構思想這篇文章中大致提了下Cache中間件,大家也對Cache中間件有了初步印象,這一節我們將談談怎麼使用Cache中間件

1.創建配置文件

cacheSettings.json

{ 
    "CachingSettings": [
      {
        "Id": "ddlCache",
        "Class": "Surging.Core.Caching.RedisCache.RedisContext,Surging.Core.Caching",
        "Properties": [
          {
            "Name": "appRuleFile",
            "Ref": "rule"
          },
          {
            "Name": "dataContextPool",
            "Ref": "ddls_sample",
            "Maps": [
              {
                "Name": "Redis",
                "Properties": [
                  {
                    "value": "127.0.0.1:6379::1"
                  }
                ]
              },
              {
                "Name": "MemoryCache"
              }
            ]
          },
          {
            "Name": "defaultExpireTime",
            "value": "120"
          },
          {
            "Name": "connectTimeout",
            "Value": "120"
          },
          {
            "Name": "minSize",
            "Value": "1"
          },
          {
            "Name": "maxSize",
            "Value": "10"
          }
        ]
      }
    ]
}

可以支持多個實例配置通過配置id來標識唯一,並且通過配置Maps,來初始化服務節點列表,通過哈希一致性來選擇服務節點

配置參數列表

參數 作用

CachingSettings

包含多個實例的父級配置節

Id

唯一標識

Class

對於Context的適配
Properties Cache 相關配置節

Maps

配置服務節列表

minSize

對象池最小數

maxSize

objectpool最大數

2.代碼配置

 

        /// <summary>
        /// 配置緩存服務
        /// </summary>
        public static void ConfigureCache(IConfigurationBuilder build)
        {
            build
              .AddCacheFile("cacheSettings.json", optional: false);
        }   

以上我們就完成了緩存中間件配置,接下來就可以通過以下代碼進行調用

基於redis的緩存調用

  cacheProvider = CacheContainer.GetInstances<ICacheProvider>(“ddlCache.Redis”);

 基於MemoryCache的緩存調用

CacheContainer.GetInstances<ICacheProvider>("MemoryCache")

4、緩存降級

對於服務所返回的數據,有些是不需要經常修改,可以通過緩存返回數據,比如商品應用,商品分類,商品列表、用戶信息,訂單信息,購物車等,通過以上需求我們就要對於proxy進行攔截,返回緩存或者刪除緩存。

對於緩存會有以下疑問

  1. 數據一致性:對於服務是分散式部署在各台伺服器上, 緩存存儲讀取也應該支持分散式,所以應該選擇支持分散式的緩存框架,如:redis,couchbase,membercache
  2. 緩存命中率:在無命中的情況下,無法直接通過緩存獲取到想要的數據,而直接通過調用遠程服務獲取數據,這樣就會增加響應時間和影響吞吐量,所以我們必須引用工具進行監控

緩存降級

 surging的緩存降級就是針對於proxy進行攔截,如果有緩存數據,則返回緩存數據,否則調用Proceed方法調用遠程服務。

 在數據進行update,delete的時候就需要針對於依賴的緩存進行刪除,可以通過proxy進行攔截的方式把緩存進行刪除

 緩存降級有以下優點

1.高性能:可以減少響應時間和提高吞吐量

2.高效:針對於業務邏輯的設計,無需考慮緩存,做到了無縫集成

以下通過示例來介紹如何使用

在業務介面方法上添加如下特性

[Command(Strategy= StrategyType.Failover,FailoverCluster =3,RequestCacheEnabled =true)]  //RequestCacheEnabled =true 就是啟用緩存

攔截獲取緩存

 [InterceptMethod(CachingMethod.Get, Key = "GetUser_id_{0}", Mode = CacheTargetType.Redis, Time = 480)]

攔截刪除緩存

[InterceptMethod(CachingMethod.Remove, "GetUser_id_{0}", "GetUserName_name_{0}", Mode = CacheTargetType.Redis)]

應用[CacheKey]來標識緩存Key,如

    public class UserModel
    {

        [CacheKey(1)]
        public int UserId { get; set; }

        public string Name { get; set; }

        public int Age { get; set; }
    }

配置攔截器

.AddClientIntercepted(typeof(CacheProviderInterceptor))

5.測試

測試環境

CPU:Intel Core i7-4710MQ

記憶體:16G

硬碟:1T SSD+512G HDD

網路:區域網

開啟redis測試結果如下: 停用Redis測試結果如下:  

6、總結

已經開始研發API網關,近期更新只會修複BUG和提交單元測試。如感興趣請多關註或者加入QQ群:615562965

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Web伺服器接收到一個客戶端請求以後,會對請求予以相應,而這個響應是通過Response來控制的, 但是在asp.net mvc 里,這部分的工作是由ActionResult來完成的, ActionResult是一個抽象類,所以具體的工作還是由很多個子類來完成, 具體的子類有 EmptyResult ...
  • 做了好幾天,對象比較多,弄的都是亂的,最後還是一個個試出來的。 Bitmap Graphics FromImage Pen Rectangle DrawRectangle 真的混亂,看了好幾天,才明白參數之間的關係。 下載 pan.baidu.com/s/1c2CMRhY 思路:form1 就是界面 ...
  • 問題3:使用webform,每次提交後臺界面都要刷新,能不能讓我們與後臺 交互的時候像ajax一樣,界面不用刷新,同時還能返回參數並且繼續在前臺執行?? 相信很多人和我一樣,這也是很多人開發放棄webform最重要的原因吧!!這也是很多人覺得webform不好的原因吧!!!其實mvc提交form表單 ...
  • 如果你沒有看我第二天寫的內容的,我想你是看不懂的!!!! 好了,廢話不多說,怎麼才能讓我們的代碼變得牛逼起來呢?怎麼封裝我們的代碼呢?我們不可能 每個頁面都需要那樣寫吧,那我們來一步一步來封裝 我們的代碼,變得更牛逼,維護性更高!!!!! 首先我們來分析,我昨天寫的代碼: 第一步:在界面寫入2個隱藏 ...
  • 問題2: 每次與後臺打交道 都需要寫一些自己都看不太懂的事件,而且傳參數很麻煩,這就是.net 封裝的事件,如何解決呢? 首先不要以為寫webfrom事件,都需要通過 伺服器控制項來綁定後臺的事件,其實說白了綁定的事件其實都是form表單提交,而且還都是id為form1的表單提交。 如果你不知道這些, ...
  • 修飾符 應用於 說明 public 所有類型或成員 任何代碼都可以訪問 protected 類型和內嵌類型的所有成員 只有派生的類型可以訪問 internal 所有類型或成員 只能在包含它的程式集中訪問 private 類型和內嵌類型的所有成員 只能在它所屬的類型中訪問 protected inte... ...
  • 1 public class Program1 2 { 3 #region 結構 4 //結構是值類型,存儲在棧上 5 //1:結構中的成員變數不能有初始值 6 //2:結構中不能聲明無參數構造函數 7 struct Example 8 { 9 //public int Width = 1;//錯誤 ...
  • 1 class Program 2 { 3 //數組是引用類型 4 //如果把數組或類等其他引用類型傳遞給方法,對應的方法就會使用該引用類型改編數組中值, 5 //而新值會反射到原始數組上 6 static void SomeFunction(int[] ints, int i) 7 { 8 int ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...