91丝袜兔女郎被啪出水在线-91丝袜兔女郎羞羞网站-91丝袜一区二区-91丝袜玉足制服脚交在线观看-91丝袜在线-91丝袜在线观看

互聯網+內容
134-1887-2552

Asp.netcore中RedisMQ的簡單應用實現

標簽:深圳網站建設公司2021-01-01 1046

這篇文章主要介紹了Asp.net core中RedisMQ的簡單應用實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

最近一個外部的項目,使用到了消息隊列,本來是用rabbitmq實現的,但是由于是部署到別人家的服務器上,想盡量簡化一些,項目中本來也要接入了redis緩存,就嘗試使用redis來實現簡單的消息隊列。

使用redis做消息隊列有兩種方法,一種是使用pub/sub,另一種是使用list結構,配合brpop來消費。這兩種方式各有特點,這里簡述一下:

pub/sub模式,支持多客戶端消費,但是不支持持久化,這就意味著客戶端斷開的時間內發布的消息將會全部舍棄掉。

list配合brpop,默認不支持多客戶端消費,支持持久化。這種模式的多客戶端消費可以變相實現,比如下面的偽代碼:

#第一步push消息到隊列
lpush listA msg
#第二步,一個專門的分發客戶端取出消息,push到各個子隊列
var msg=brpop listA
lpush listA1 msg
lpush listA2 msg
......
#第三步,多個客戶端從對應的隊列消費消息
var client1_msg= brpop listA1
var client2_msg= brpop listA2
......

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

Stackexchange.redis 算是一個老牌的客戶端了,但是由于其采用多路復用的模式,沒法支持Redis的blocking pops特性。所以我采用了國人寫的CSRedisCore。

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

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

具體配置請參考github上的文檔:

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

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

當然也可以采用依賴注入的方式添加CSRedisClient實例,這個不糾結。

在項目中有好幾處使用到了隊列,所以先封裝一個消費服務:

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))
{
//加入錯誤處理隊列,可以在后臺寫功能手動處理
RedisHelper.LPush(CacheKey + "_err", msg);
}
}
catch (Exception exp)
{
//加入錯誤處理隊列,可以在后臺寫功能手動處理
RedisHelper.LPush(CacheKey + "_err", msg);
logger.LogError(exp, "RedisMQConsumer Execute error");
}
}
catch
{
//網絡可能中斷
await Task.Delay(TimeSpan.FromSeconds(5), stoppingToken);
}

}
}, stoppingToken);
}

protected abstract bool Process(string message);
}

然后就可以繼承RedisMQConsumer,編寫實際邏輯:

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;
}
}

發布消息只是往隊列中添加項:

RedisHelper.LPush("addOrder", order);

最后把消費服務添加到startup.cs中:

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

//redis消息隊列消費服務,放在redis配置下方
services.AddHostedService<AddOrderMQConsumer>();
}

經測試,還算穩定,小并發項目可以使用。

到此這篇關于Asp.net core中RedisMQ的簡單應用實現的文章就介紹到這了,更多相關Asp.net core RedisMQ內容請搜索深圳網站建設公司自由創想以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持深圳網站建設公司自由創想!

微信分享領紅包!
相關閱讀 / 返回上一頁
主站蜘蛛池模板: 人妻丰满熟妇区毛片 | 精品国产a∨一区二区三区在线 | 中文字幕无码乱人伦一区二区三区 | 无码中文字幕色99蜜臀av无码波多野结衣 | 欧美疯狂做受xxxxx高潮 | 中文字幕一区二区三区精彩视频 | 在线视频中文字幕 | 人人妻人人藻人人爽欧美一区 | 成人性生交大片免费看黄9.1 | 成人精品一区二区三区久久 | 91香蕉视频在线播放 | 成人精品一区二区三区久久 | 伊人精品成人 | 97久久精品无码一区二区 | 亚洲不av无| 99精品视频在线观看 | 91精品久久久久久综合五月天 | 无码丰满少妇2在线观看 | 国产日韩高清不卡综合 | 91情侣在线精品国产 | 日韩欧美a级 | 国产乱码一区二区三区 | 日韩欧美精品一区二区三区 | 国产伦精品一区二区三区网站 | 亚洲av激情无码专区在线播放 | 精品一区二区久久久久久久网站 | 亚洲成a人片在线播放观看国 | 丰满少妇一级毛片亚洲日韩 | 日本高清精品色视频网二区 | 国产在线视频福利资源站 | 亚洲手机在线人成网站 | 亚洲无码高清h片 | 免费av无| 午夜无码精品免费观看 | 91午夜精品久久久久精品 | 日本a级毛片在网络上引发争议 | 91精品国产高清久久久久久io | 亚洲午夜一区二区三区在线观看 | 国产成年无码aⅴ片在线韩国 | 亚洲成a人无码 | 97青草香蕉依人在线播放 |