本篇文章主要介紹了.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");}
下面運行了一個發布用戶端,兩個訂閱用戶端: