.net core如何使用Redis發(fā)布訂閱
Redis是一個性能非常強(qiáng)勁的內(nèi)存數(shù)據(jù)庫,它一般是作為緩存來使用,但是他不僅僅可以用來作為緩存,比如著名的分布式框架dubbo就可以用Redis來做服務(wù)注冊中心。接下來介紹一下.net core 使用Redis的發(fā)布/訂閱功能。
Redis 發(fā)布訂閱
Redis 發(fā)布訂閱(pub/sub)是一種消息通信模式:發(fā)送者(pub)發(fā)送消息,訂閱者(sub)接收消息。
Redis 客戶端可以訂閱任意數(shù)量的通道。
下圖展示了頻道 channel1 , 以及訂閱這個頻道的三個客戶端 —— client2 、 client5 和 client1 之間的關(guān)系:
當(dāng)有新消息通過 PUBLISH 命令發(fā)送給頻道 channel1 時, 這個消息就會被發(fā)送給訂閱它的三個客戶端:
使用Redis命令
首先,通過subscribe redismessage命令使兩個客戶端訂閱redismessage通道:
然后再打開一個Redis客戶端,使用命令publish redismessage "消息內(nèi)容"發(fā)布消息
使用.net core 實現(xiàn)
這里我選擇的連接驅(qū)動為 StackExchange.Redis,這里需要注意的是 ServiceStack.Redis連接驅(qū)動已經(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("請輸入任意字符,輸入exit退出"); string input; do { input = Console.ReadLine(); sub.Publish("messages", input); } while (input != "exit"); }
下面運(yùn)行了一個發(fā)布客戶端,兩個訂閱客戶端:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
asp.net 更改gridview pageSize的方法
asp.net 更改gridview pageSize的方法,需要的朋友可以參考下。2011-07-07.NET?Core基于EMIT編寫的輕量級AOP框架CZGL.AOP
這篇文章介紹了.NET?Core基于EMIT編寫的輕量級AOP框架CZGL.AOP,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-02-02.Net Core簡單使用Mvc內(nèi)置的Ioc(續(xù))
怎樣直接獲取Ioc中的實例對象,而不是以構(gòu)造函數(shù)的方式進(jìn)行獲取呢?這篇文章繼續(xù)為大家介紹.Net Core簡單使用Mvc內(nèi)置的Ioc2018-03-03DataList 中動態(tài)綁定服務(wù)器子控件的代碼
DataList 中動態(tài)綁定服務(wù)器子控件的代碼...2007-09-09Visual Studio 2017 (VS 2017)離線安裝包制作方法
這篇文章主要為大家詳細(xì)介紹了Visual Studio 2017離線安裝包的制作方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03ASP.NET MVC 中實現(xiàn)基于角色的權(quán)限控制的處理方法
在ASP.NET MVC中,通過使用其所提供的內(nèi)置2013-03-03擴(kuò)展ASP.NET MVC三層框架且使用StructureMap實現(xiàn)依賴注入1-Model層
本篇文章將向大家介紹如何添加Service和Repository層并且使用StructureMap把Service層注入到Controller,把Repository注入到Service層。2013-04-04