天天做天天爱天天综合网-天天做天天爱天天影视综合-天天做天天爱天天爽综合区-天天做天天爱天天爽天天综合-福利一区二区在线观看-福利一区二区视频

互聯(lián)網(wǎng)+內(nèi)容
134-1887-2552

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

標(biāo)簽:深圳網(wǎng)站建設(shè)公司2021-01-01 967

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

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

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

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

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è)客戶端從對應(yīng)的隊(duì)列消費(fèi)消息
var client1_msg= brpop listA1
var client2_msg= brpop listA2
......

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

Stackexchange.redis 算是一個(gè)老牌的客戶端了,但是由于其采用多路復(fù)用的模式,沒法支持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")));
}

當(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ì)列,可以在后臺寫功能手動處理
RedisHelper.LPush(CacheKey + "_err", msg);
}
}
catch (Exception exp)
{
//加入錯(cuò)誤處理隊(duì)列,可以在后臺寫功能手動處理
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)測試,還算穩(wěn)定,小并發(fā)項(xiàng)目可以使用。

到此這篇關(guān)于Asp.net core中RedisMQ的簡單應(yīng)用實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)Asp.net core RedisMQ內(nèi)容請搜索深圳網(wǎng)站建設(shè)公司自由創(chuàng)想以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持深圳網(wǎng)站建設(shè)公司自由創(chuàng)想!

微信分享領(lǐng)紅包!
相關(guān)閱讀 / 返回上一頁
主站蜘蛛池模板: 国产在线视频网| 亚洲一区二区三区四| 在线欧美日韩| 亚洲第七页| 国产原创91| 久久免费国产精品一区二区| 久久久久九九| 国产日韩一区二区三区| 日韩精品成人在线| 色接久久| 91麻豆视频网站| 96精品在线| 亚洲欧洲一区| 亚洲日韩欧美一区二区在线| 99999久久久久久亚洲| 国产视频首页| 国产在线欧美日韩精品一区二区 | 欧美午夜视频在线观看| 日韩 欧美 中文| 91亚洲 欧美 国产 制服 动漫| 特黄特黄aaaa级毛片免费看| 日本欧美韩国专区| 国产高清不卡一区二区三区| 国产精品视频久久久久久| 亚洲欧美日韩在线观看| 亚洲全黄| 日韩经典欧美一区二区三区| 91精品观看91久久久久久| 日韩欧美一区二区三区在线| 欧美91精品| 欧美成人免费高清视频| 国产成人精品久久一区二区三区| 久久久国产精品视频| 在线亚洲激情| 曰韩欧美| 高清视频一区| 伊人色综合97| 欧美成人国产| 精品欧美在线观看| 亚洲精品免费视频| 欧美日韩专区|