Asp.net core中RedisMQ的簡單應(yīng)用實現(xiàn)
最近一個外部的項目,使用到了消息隊列,本來是用rabbitmq實現(xiàn)的,但是由于是部署到別人家的服務(wù)器上,想盡量簡化一些,項目中本來也要接入了redis緩存,就嘗試使用redis來實現(xiàn)簡單的消息隊列。
使用redis做消息隊列有兩種方法,一種是使用pub/sub,另一種是使用list結(jié)構(gòu),配合brpop來消費。這兩種方式各有特點,這里簡述一下:
- pub/sub模式,支持多客戶端消費,但是不支持持久化,這就意味著客戶端斷開的時間內(nèi)發(fā)布的消息將會全部舍棄掉。
- list配合brpop,默認不支持多客戶端消費,支持持久化。這種模式的多客戶端消費可以變相實現(xiàn),比如下面的偽代碼:
#第一步push消息到隊列 lpush listA msg #第二步,一個專門的分發(fā)客戶端取出消息,push到各個子隊列 var msg=brpop listA lpush listA1 msg lpush listA2 msg ...... #第三步,多個客戶端從對應(yīng)的隊列消費消息 var client1_msg= brpop listA1 var client2_msg= brpop listA2 ......
消息丟失不太可取,所以我選擇了list ,下一步需要選擇一個合適的客戶端。
Stackexchange.redis 算是一個老牌的客戶端了,但是由于其采用多路復(fù)用的模式,沒法支持Redis的blocking pops特性。所以我采用了國人寫的CSRedisCore。
首先需要在appsettings.json中添加redis的連接字符串:
{
"ConnectionStrings": {
"redis": "{ip}:{port},password=123456,prefix=my_"
}
}
具體配置請參考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實例,這個不糾結(jié)。
在項目中有好幾處使用到了隊列,所以先封裝一個消費服務(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))
{
//加入錯誤處理隊列,可以在后臺寫功能手動處理
RedisHelper.LPush(CacheKey + "_err", msg);
}
}
catch (Exception exp)
{
//加入錯誤處理隊列,可以在后臺寫功能手動處理
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,編寫實際邏輯:
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ā)布消息只是往隊列中添加項:
RedisHelper.LPush("addOrder", order);
最后把消費服務(wù)添加到startup.cs中:
public void ConfigureServices(IServiceCollection services)
{
//redis配置
RedisHelper.Initialization(new CSRedis.CSRedisClient(Configuration.GetConnectionString("redis")));
//redis消息隊列消費服務(wù),放在redis配置下方
services.AddHostedService<AddOrderMQConsumer>();
}
經(jīng)測試,還算穩(wěn)定,小并發(fā)項目可以使用。
到此這篇關(guān)于Asp.net core中RedisMQ的簡單應(yīng)用實現(xiàn)的文章就介紹到這了,更多相關(guān)Asp.net core RedisMQ內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Redis數(shù)據(jù)庫基礎(chǔ)與ASP.NET?Core緩存實現(xiàn)
- ASP.NET?Core擴展庫ServiceStack.Redis用法介紹
- 詳解ASP.Net Core 中如何借助CSRedis實現(xiàn)一個安全高效的分布式鎖
- .NET Core中使用Redis與Memcached的序列化問題詳析
- .net core如何使用Redis發(fā)布訂閱
- .net core使用redis基于StackExchange.Redis
- 詳解Asp.net Core 使用Redis存儲Session
- 詳解如何在ASP.NET Core中使用Redis
- .NET?Core實現(xiàn)簡單的Redis?Client框架
相關(guān)文章
ASP.NET生成樹形顯示的GridView實現(xiàn)思路
生成樹形結(jié)構(gòu)的表格數(shù)據(jù)(EasyUI也有TreeGrid,此處只是提供一個思路),可以擴展單擊展開/收縮節(jié)點,喜歡的朋友可以了解下啊,或許本文對你學(xué)習(xí)GridView有所幫助2013-02-02
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ù)庫連接詳解
本文將詳細介紹如何使用Connection對象連接數(shù)據(jù)庫 。對于不同的.NET 數(shù)據(jù)提供者,ADO.NET采用不同的Connection對象連接數(shù)據(jù)庫。這些Connection對象為我們屏蔽了具體的實現(xiàn)細節(jié),并提供了一種統(tǒng)一的實現(xiàn)方法。2009-07-07
asp.net基于HashTable實現(xiàn)購物車的方法
這篇文章主要介紹了asp.net基于HashTable實現(xiàn)購物車的方法,涉及asp.net中HashTable結(jié)合session實現(xiàn)購物車功能的相關(guān)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-12-12
關(guān)于Metalama使用Fabric操作項目或命名空間的問題
Metalama是一個基于微軟編譯器Roslyn的元編程的庫,可以解決我在開發(fā)中遇到的重復(fù)代碼的問題,這篇文章主要介紹了Metalama使用Fabric操作項目或命名空間,需要的朋友可以參考下2022-04-04
.net6環(huán)境下使用RestSharp請求GBK編碼網(wǎng)頁亂碼的解決方案
這篇文章介紹了.net6環(huán)境下使用RestSharp請求GBK編碼網(wǎng)頁亂碼的解決方案,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12

