Redis是一個性能非常強勁的記憶體資料庫,它一般是作為緩存來使用,但是他不僅僅可以用來作為緩存,比如著名的分布式架構dubbo就可以用Redis來做服務注冊中心。接下來介紹一下.net core 使用Redis的釋出/訂閱功能。
Redis 釋出訂閱
Redis 釋出訂閱(pub/sub)是一種消息通信模式:發送者(pub)發送消息,訂閱者(sub)接收消息。
Redis 用戶端可以訂閱任意數量的通道。
下圖展示了頻道 channel1 , 以及訂閱這個頻道的三個用戶端 —— client2 、 client5 和 client1 之間的關系:

當有新消息通過 PUBLISH 指令發送給頻道 channel1 時, 這個消息就會被發送給訂閱它的三個用戶端:
使用Redis指令
首先,通過
subscribe redismessage
指令使兩個用戶端訂閱redismessage通道:
然後再打開一個Redis用戶端,使用指令
publish redismessage "消息内容"
釋出消息
使用.net core 實作
這裡我選擇的連接配接驅動為
StackExchange.Redis
,這裡需要注意的是
ServiceStack.Redis
連接配接驅動已經逐漸商業化,4.0及以上版本都具有限制,是以選擇的免費且好用的StackExchange.Redis,使用nuget安裝即可。
建立訂閱用戶端
//建立連接配接
using (ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("127.0.0.1:6379"))
{
ISubscriber sub = redis.GetSubscriber();
//訂閱名為 messages 的通道
sub.Subscribe("messages", (channel, message) => {
//輸出收到的消息
Console.WriteLine($"[{DateTime.Now:HH:mm:ss}] {message}");
});
Console.WriteLine("已訂閱 messages");
Console.ReadKey();
}
建立釋出用戶端
//建立連接配接
using (ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("127.0.0.1:6379"))
{
ISubscriber sub = redis.GetSubscriber();
Console.WriteLine("請輸入任意字元,輸入exit退出");
string input;
do
{
input = Console.ReadLine();
sub.Publish("messages", input);
} while (input != "exit");
}
下面運作了一個釋出用戶端,兩個訂閱用戶端:
Demo下載下傳
目前學習.NET Core 最好的教程 .NET Core 官方教程 ASP.NET Core 官方教程
.NET Core 交流群:923036995 歡迎加群交流
如果您認為這篇文章還不錯或者有所收獲,您可以點選右下角的【推薦】支援,或請我喝杯咖啡【贊賞】,這将是我繼續寫作,分享的最大動力!
作者:曉晨Master(李志強)
聲明:原創部落格請在轉載時保留原文連結或者在文章開頭加上本人部落格位址,如發現錯誤,歡迎批評指正。凡是轉載于本人的文章,不能設定打賞功能,如有特殊需求請與本人聯系!