欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Asp.net core中RedisMQ的簡(jiǎn)單應(yīng)用實(shí)現(xiàn)

 更新時(shí)間:2020年12月09日 09:10:27   作者:拉克斯文  
這篇文章主要介紹了Asp.net core中RedisMQ的簡(jiǎn)單應(yīng)用實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

最近一個(gè)外部的項(xiàng)目,使用到了消息隊(duì)列,本來(lái)是用rabbitmq實(shí)現(xiàn)的,但是由于是部署到別人家的服務(wù)器上,想盡量簡(jiǎn)化一些,項(xiàng)目中本來(lái)也要接入了redis緩存,就嘗試使用redis來(lái)實(shí)現(xiàn)簡(jiǎn)單的消息隊(duì)列。

使用redis做消息隊(duì)列有兩種方法,一種是使用pub/sub,另一種是使用list結(jié)構(gòu),配合brpop來(lái)消費(fèi)。這兩種方式各有特點(diǎn),這里簡(jiǎn)述一下:

  • pub/sub模式,支持多客戶(hù)端消費(fèi),但是不支持持久化,這就意味著客戶(hù)端斷開(kāi)的時(shí)間內(nèi)發(fā)布的消息將會(huì)全部舍棄掉。
  • list配合brpop,默認(rèn)不支持多客戶(hù)端消費(fèi),支持持久化。這種模式的多客戶(hù)端消費(fèi)可以變相實(shí)現(xiàn),比如下面的偽代碼:
#第一步push消息到隊(duì)列
lpush listA msg
#第二步,一個(gè)專(zhuān)門(mén)的分發(fā)客戶(hù)端取出消息,push到各個(gè)子隊(duì)列
var msg=brpop listA
lpush listA1 msg
lpush listA2 msg
......
#第三步,多個(gè)客戶(hù)端從對(duì)應(yīng)的隊(duì)列消費(fèi)消息
var client1_msg= brpop listA1
var client2_msg= brpop listA2
......

消息丟失不太可取,所以我選擇了list ,下一步需要選擇一個(gè)合適的客戶(hù)端。
Stackexchange.redis 算是一個(gè)老牌的客戶(hù)端了,但是由于其采用多路復(fù)用的模式,沒(méi)法支持Redis的blocking pops特性。所以我采用了國(guó)人寫(xiě)的CSRedisCore。

首先需要在appsettings.json中添加redis的連接字符串:

{
 "ConnectionStrings": {
  "redis": "{ip}:{port},password=123456,prefix=my_"
 }
}

具體配置請(qǐng)參考github上的文檔:https://github.com/2881099/csredis

然后在startup.cs的ConfigureServices中配置redis:

    public void ConfigureServices(IServiceCollection services)
    {
      //redis配置
      RedisHelper.Initialization(new CSRedis.CSRedisClient(Configuration.GetConnectionString("redis")));
    }

當(dāng)然也可以采用依賴(lài)注入的方式添加CSRedisClient實(shí)例,這個(gè)不糾結(jié)。

在項(xiàng)目中有好幾處使用到了隊(duì)列,所以先封裝一個(gè)消費(fèi)服務(wù):

  public abstract class RedisMQConsumer : BackgroundService
  {
    protected abstract string CacheKey { get; }

    protected ILogger<RedisMQConsumer> logger;

    public RedisMQConsumer(ILogger<RedisMQConsumer> logger)
    {
      this.logger = logger;
    }

    protected override Task ExecuteAsync(CancellationToken stoppingToken)
    {
      return Task.Run( async() =>
      {
        while (!stoppingToken.IsCancellationRequested)
        {
          try
          {
            var msg = RedisHelper.BRPop(5, CacheKey);
            try
            {
              if (string.IsNullOrEmpty(msg)) continue;
              if (!Process(msg))
              {
                //加入錯(cuò)誤處理隊(duì)列,可以在后臺(tái)寫(xiě)功能手動(dòng)處理
                RedisHelper.LPush(CacheKey + "_err", msg);
              }
            }
            catch (Exception exp)
            {
              //加入錯(cuò)誤處理隊(duì)列,可以在后臺(tái)寫(xiě)功能手動(dòng)處理
              RedisHelper.LPush(CacheKey + "_err", msg);
              logger.LogError(exp, "RedisMQConsumer Execute error");
            }
          }
          catch
          {
            //網(wǎng)絡(luò)可能中斷
            await Task.Delay(TimeSpan.FromSeconds(5), stoppingToken);
          }
            
        }
      }, stoppingToken);
    }

    protected abstract bool Process(string message);
  }

然后就可以繼承RedisMQConsumer,編寫(xiě)實(shí)際邏輯:

  public class AddOrderMQConsumer : RedisMQConsumer
  {
    public AddOrderMQConsumer(ILogger<RedisMQConsumer> logger) : base(logger)
    {
    }
    protected override string CacheKey => "addOrder";
    protected override bool Process(string message)
    {
      var order = JsonSerializer.Deserialize<Order>(message);
      //處理邏輯
      return true;
    }
  }

發(fā)布消息只是往隊(duì)列中添加項(xiàng):

RedisHelper.LPush("addOrder", order);

最后把消費(fèi)服務(wù)添加到startup.cs中:

    public void ConfigureServices(IServiceCollection services)
    {
      //redis配置
      RedisHelper.Initialization(new CSRedis.CSRedisClient(Configuration.GetConnectionString("redis")));
      
      //redis消息隊(duì)列消費(fèi)服務(wù),放在redis配置下方
      services.AddHostedService<AddOrderMQConsumer>();
    }

經(jīng)測(cè)試,還算穩(wěn)定,小并發(fā)項(xiàng)目可以使用。

到此這篇關(guān)于A(yíng)sp.net core中RedisMQ的簡(jiǎn)單應(yīng)用實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Asp.net core RedisMQ內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • ASP.NET生成樹(shù)形顯示的GridView實(shí)現(xiàn)思路

    ASP.NET生成樹(shù)形顯示的GridView實(shí)現(xiàn)思路

    生成樹(shù)形結(jié)構(gòu)的表格數(shù)據(jù)(EasyUI也有TreeGrid,此處只是提供一個(gè)思路),可以擴(kuò)展單擊展開(kāi)/收縮節(jié)點(diǎn),喜歡的朋友可以了解下啊,或許本文對(duì)你學(xué)習(xí)GridView有所幫助
    2013-02-02
  • .NET 緩存模塊設(shè)計(jì)實(shí)踐

    .NET 緩存模塊設(shè)計(jì)實(shí)踐

    這篇承接上篇對(duì)緩存的概念,框架上的理解,講講緩存模塊設(shè)計(jì)實(shí)踐過(guò)程,感興趣的小伙伴們可以參考一下
    2016-08-08
  • asp.net調(diào)用系統(tǒng)設(shè)置字體文本框的方法

    asp.net調(diào)用系統(tǒng)設(shè)置字體文本框的方法

    這篇文章主要介紹了asp.net調(diào)用系統(tǒng)設(shè)置字體文本框的方法,包括設(shè)置文本字體樣式和大小,需要的朋友可以參考下
    2014-09-09
  • ASP.NET2.0 SQL Server數(shù)據(jù)庫(kù)連接詳解

    ASP.NET2.0 SQL Server數(shù)據(jù)庫(kù)連接詳解

    本文將詳細(xì)介紹如何使用Connection對(duì)象連接數(shù)據(jù)庫(kù) 。對(duì)于不同的.NET 數(shù)據(jù)提供者,ADO.NET采用不同的Connection對(duì)象連接數(shù)據(jù)庫(kù)。這些Connection對(duì)象為我們屏蔽了具體的實(shí)現(xiàn)細(xì)節(jié),并提供了一種統(tǒng)一的實(shí)現(xiàn)方法。
    2009-07-07
  • 基于A(yíng)SP.NET實(shí)現(xiàn)驗(yàn)證碼生成詳解

    基于A(yíng)SP.NET實(shí)現(xiàn)驗(yàn)證碼生成詳解

    這篇文章主要為大家詳細(xì)介紹了如何利用ASP.NET實(shí)現(xiàn)驗(yàn)證碼的生成,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • asp.net基于HashTable實(shí)現(xiàn)購(gòu)物車(chē)的方法

    asp.net基于HashTable實(shí)現(xiàn)購(gòu)物車(chē)的方法

    這篇文章主要介紹了asp.net基于HashTable實(shí)現(xiàn)購(gòu)物車(chē)的方法,涉及asp.net中HashTable結(jié)合session實(shí)現(xiàn)購(gòu)物車(chē)功能的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-12-12
  • ASP.NET Core中使用LazyCache的全過(guò)程

    ASP.NET Core中使用LazyCache的全過(guò)程

    這篇文章主要給大家介紹了關(guān)于A(yíng)SP.NET Core中使用LazyCache的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • 關(guān)于Metalama使用Fabric操作項(xiàng)目或命名空間的問(wèn)題

    關(guān)于Metalama使用Fabric操作項(xiàng)目或命名空間的問(wèn)題

    Metalama是一個(gè)基于微軟編譯器Roslyn的元編程的庫(kù),可以解決我在開(kāi)發(fā)中遇到的重復(fù)代碼的問(wèn)題,這篇文章主要介紹了Metalama使用Fabric操作項(xiàng)目或命名空間,需要的朋友可以參考下
    2022-04-04
  • .net實(shí)現(xiàn)ping的實(shí)例代碼

    .net實(shí)現(xiàn)ping的實(shí)例代碼

    這篇文章主要介紹了.net實(shí)現(xiàn)ping的實(shí)例代碼,需要的朋友可以參考下
    2014-02-02
  • .net6環(huán)境下使用RestSharp請(qǐng)求GBK編碼網(wǎng)頁(yè)亂碼的解決方案

    .net6環(huán)境下使用RestSharp請(qǐng)求GBK編碼網(wǎng)頁(yè)亂碼的解決方案

    這篇文章介紹了.net6環(huán)境下使用RestSharp請(qǐng)求GBK編碼網(wǎng)頁(yè)亂碼的解決方案,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-12-12

最新評(píng)論