.net core 使用Redis的發布訂閱


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下載


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM