.net core 使用Redis的发布订阅
Redis是一個(gè)性能非常強(qiáng)勁的內(nèi)存數(shù)據(jù)庫(kù),它一般是作為緩存來(lái)使用,但是他不僅僅可以用來(lái)作為緩存,比如著名的分布式框架dubbo就可以用Redis來(lái)做服務(wù)注冊(cè)中心。接下來(lái)介紹一下.net core 使用Redis的發(fā)布/訂閱功能。
Redis 發(fā)布訂閱
Redis 發(fā)布訂閱(pub/sub)是一種消息通信模式:發(fā)送者(pub)發(fā)送消息,訂閱者(sub)接收消息。
Redis 客戶端可以訂閱任意數(shù)量的通道。
下圖展示了頻道 channel1 , 以及訂閱這個(gè)頻道的三個(gè)客戶端 —— client2 、 client5 和 client1 之間的關(guān)系:
當(dāng)有新消息通過(guò) PUBLISH 命令發(fā)送給頻道 channel1 時(shí), 這個(gè)消息就會(huì)被發(fā)送給訂閱它的三個(gè)客戶端:
使用Redis命令
首先,通過(guò)subscribe redismessage命令使兩個(gè)客戶端訂閱redismessage通道:
然后再打開(kāi)一個(gè)Redis客戶端,使用命令publish redismessage "消息內(nèi)容"發(fā)布消息
使用.net core 實(shí)現(xiàn)
這里我選擇的連接驅(qū)動(dòng)為?StackExchange.Redis,這里需要注意的是?ServiceStack.Redis連接驅(qū)動(dòng)已經(jīng)逐漸商業(yè)化,4.0及以上版本都具有限制,所以選擇的免費(fèi)且好用的StackExchange.Redis,使用nuget安裝即可。
建立訂閱客戶端
//創(chuàng)建連接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(); }
建立發(fā)布客戶端
//創(chuàng)建連接using (ConnectionMultiplexer redis = ConnectionMultiplexer.Connect("127.0.0.1:6379")) {ISubscriber sub = redis.GetSubscriber();Console.WriteLine("請(qǐng)輸入任意字符,輸入exit退出"); ??string input; ? ?do{input = Console.ReadLine();sub.Publish("messages", input);} while (input != "exit"); }
下面運(yùn)行了一個(gè)發(fā)布客戶端,兩個(gè)訂閱客戶端:
相關(guān)文章:?
理解并從頭搭建redis集群
asp.net core 實(shí)戰(zhàn)之 redis 負(fù)載均衡和"高可用"實(shí)現(xiàn)
原文地址:http://www.cnblogs.com/stulzq/p/7542012.html
.NET社區(qū)新聞,深度好文,微信中搜索dotNET跨平臺(tái)或掃描二維碼關(guān)注
總結(jié)
以上是生活随笔為你收集整理的.net core 使用Redis的发布订阅的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 是时候开始用C#快速开发移动应用了
- 下一篇: “.Net 社区大会”(dotnetCo