乱码乱a∨中文字幕,在线免费激情视频,亚洲欧美久久夜夜潮,国产在线网址

  1. <sub id="hjl7n"></sub>

    1. <sub id="hjl7n"></sub>

      <legend id="hjl7n"></legend>

      當(dāng)前位置:首頁 >  站長(zhǎng) >  編程技術(shù) >  正文

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

       2020-12-31 16:57  來源: 腳本之家   我來投稿 撤稿糾錯(cuò)

        阿里云優(yōu)惠券 先領(lǐng)券再下單

      這篇文章主要介紹了Asp.net core中RedisMQ的簡(jiǎn)單應(yīng)用實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

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

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

      pub/sub模式,支持多客戶端消費(fèi),但是不支持持久化,這就意味著客戶端斷開的時(shí)間內(nèi)發(fā)布的消息將會(huì)全部舍棄掉。

      list配合brpop,默認(rèn)不支持多客戶端消費(fèi),支持持久化。這種模式的多客戶端消費(fèi)可以變相實(shí)現(xiàn),比如下面的偽代碼:

      #第一步push消息到隊(duì)列
      lpush listA msg
      #第二步,一個(gè)專門的分發(fā)客戶端取出消息,push到各個(gè)子隊(duì)列
      var msg=brpop listA
      lpush listA1 msg
      lpush listA2 msg
      ......
      #第三步,多個(gè)客戶端從對(duì)應(yīng)的隊(duì)列消費(fèi)消息
      var client1_msg= brpop listA1
      var client2_msg= brpop listA2
      ......

      消息丟失不太可取,所以我選擇了list ,下一步需要選擇一個(gè)合適的客戶端。

      Stackexchange.redis 算是一個(gè)老牌的客戶端了,但是由于其采用多路復(fù)用的模式,沒法支持Redis的blocking pops特性。所以我采用了國(guó)人寫的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)然也可以采用依賴注入的方式添加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)寫功能手動(dòng)處理
      RedisHelper.LPush(CacheKey + "_err", msg);
      }
      }
      catch (Exception exp)
      {
      //加入錯(cuò)誤處理隊(duì)列,可以在后臺(tái)寫功能手動(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,編寫實(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)于Asp.net core中RedisMQ的簡(jiǎn)單應(yīng)用實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Asp.net core RedisMQ內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

      來源:腳本之家

      鏈接:https://www.jb51.net/article/201718.htm

      申請(qǐng)創(chuàng)業(yè)報(bào)道,分享創(chuàng)業(yè)好點(diǎn)子。點(diǎn)擊此處,共同探討創(chuàng)業(yè)新機(jī)遇!

      相關(guān)標(biāo)簽
      asp.net
      net開發(fā)
      .net開發(fā)

      相關(guān)文章

      熱門排行

      信息推薦