欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Redis發(fā)布訂閱和實現(xiàn).NET客戶端詳解

 更新時間:2017年03月21日 15:34:55   作者:張龍豪  
發(fā)布訂閱在應用級其作用是為了減少依賴關系,通常也叫觀察者模式。主要是把耦合點單獨抽離出來作為第三方,隔離易變化的發(fā)送方和接收方。下面這篇文章主要給大家介紹了關于Redis發(fā)布訂閱和實現(xiàn).NET客戶端的相關資料,需要的朋友可以參考下

前言

發(fā)布訂閱在設計模式中也可以說是觀察者模式,針對這個模式是處理對象間一對多的依賴關系的,當一個對象發(fā)生變化,其它依賴他的對象都要得到通知并更新。

然而它也有自己的缺點,就是當主題發(fā)生一系列的變化時,觀察者都要做批量的更新,如果這樣的更新成本很高,那么解決方法就是根據(jù)種類需求通知,而不能盲目的通知所有的觀察者。

那針對這個缺點,一般的情況下,你沒有需求誰訂閱一個跟自己無關的消息推送呢?這也正好說明推送的消息需要整理而不能一窩蜂的什么消息都往一個通道里面拋,要分而治之,合理的設計發(fā)布通道的用途,也合理的訂閱通道。

那么如此一來,升級到系統(tǒng)項目級別,他別給我們又帶來啦,莫大的好處,便是:剝離系統(tǒng)耦合,減少單線功能的依賴關系,又正迎合啦高內(nèi)聚,松耦合的系統(tǒng)架構設計。

Redis中的發(fā)布/訂閱功能

這一節(jié)參考官方文檔:https://redis.io/topics/pubsub

首先我準備啦1個redis服務,3個客戶端,如下圖所示:

 

然后打開官方文檔,首先可以看到以下6個命令,對,就只有這6個命令,只要你能掌握理解,發(fā)散思維靈活運用。吐納,吐納,那么道于此,生一,生二、生三,生萬物,根本不在話下??!C,C,C,WC, 小伙,以后拯救世界就看你啦。

 

下面我們使用這幾個命令,做一個演示,便于你理解。

1、2個客戶端訂閱order.create通道消息,如下:

 

2、最后一個客戶端發(fā)布往order.create通道發(fā)布消息。如下:

 

3、你會立馬發(fā)現(xiàn)訂閱此通道的另外2個客戶端有信息輸出出來,如下:

 

簡單不,一個發(fā)布訂閱的基礎功能以及完事啦。

那如果你對其他一些發(fā)布訂閱管理系統(tǒng)比較了解的話,你立馬會想到一個功能,類似rabbitmq中的topic類型的匹配功能。那redis中有嗎,就這6個命令,答案是有的。使用的命令為psubscribe。

127.0.0.1:6379> psubscribe * ---訂閱所有通道
127.0.0.1:6379> psubscribe order.* ---訂閱通道名稱以order.開頭的所有通道消息

那又如何取消訂閱過的通道呢?

127.0.0.1:6379> unsubscribe order.create ---取消訂閱
127.0.0.1:6379> punsubscribe order.* ---取消訂閱通道名稱以order.開頭的所有通道消息

如何查看訂閱信息呢?

127.0.0.1:6379> pubsub channels ---查看當前服務器訂閱的所有通道
127.0.0.1:6379> pubsub channels order.* ---查看訂閱通道名稱以order.開頭的所有通道
127.0.0.1:6379> pubsub numsub order.create user ---查看訂閱order.create 和user 通道的訂閱者數(shù)量,支持查詢多個通道

呀,到此為止,6個命令已經(jīng)用完啦。就是這么任性,對,你潛心修煉10多分鐘已經(jīng)學會啦redis中最上層的發(fā)布訂閱技能。你可以出關,打敗天下無敵手啦。

StackExchange.Redis實現(xiàn)redis中的發(fā)布訂閱功能

那這一節(jié)呢,我也實在說不出怎么講更合理點,我就上一個示例,你自己把代碼拷貝去,玩玩吧。上代碼。

static void Main(string[] args)
  {
   Console.WriteLine("請輸入發(fā)布訂閱類型?");
   var type = Console.ReadLine();
   if (type == "publish")
   {
    while (true)
    {
     Console.WriteLine("請輸入要發(fā)布向哪個通道?");
     var channel = Console.ReadLine();
     Console.WriteLine("請輸入要發(fā)布的消息內(nèi)容.");
     var message = Console.ReadLine();
     sub.Publish(channel, message);
    }
   }
   else
   {
    Console.WriteLine("請輸入您要訂閱哪個通道的信息?");
    var channelKey = Console.ReadLine();
    sub.Subscribe(channelKey, (channel, message) =>
    {
     Console.WriteLine("接受到發(fā)布的內(nèi)容為:" + message);
    });
    Console.WriteLine("您訂閱的通道為:<< "+ channelKey + " >> ! 一切就緒,等待發(fā)布消息!勿動,一動就沒啦??!");
    Console.ReadKey();
   }
  }

運行起來幾個實例,來玩一玩。如下,5個,1個發(fā)布信息,4個訂閱信息,其中2個訂閱zhanglonghao通道,2個訂閱bokeyuan通道。

 

第一次我發(fā)布消息到zhanglonghao通道,發(fā)布的消息為:hello shuaige ?。∪缦拢?/p>

 

可以看出只有訂閱zhanglonghao通道的才接受到啦消息。

那再往bokeyuan通道里面發(fā)送,hello bokeyuan !

 

到此為止,自己玩去吧。

總結

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關文章

  • Redis模仿發(fā)送手機驗證碼功能

    Redis模仿發(fā)送手機驗證碼功能

    這篇文章主要介紹了Redis模仿手機驗證碼發(fā)送功能,通過示例代碼給大家講解通過用戶輸入手機號以及驗證碼進行校驗,代碼簡單易懂,需要的朋友可以參考下
    2021-09-09
  • redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法

    redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法

    這篇文章主要為大家詳細介紹了redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • redis三種高可用方式部署的實現(xiàn)

    redis三種高可用方式部署的實現(xiàn)

    這篇文章主要介紹了redis三種高可用方式部署的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-05-05
  • 查看Redis內(nèi)存信息的命令

    查看Redis內(nèi)存信息的命令

    Redis 是一個開源、高性能的Key-Value數(shù)據(jù)庫,被廣泛應用在服務器各種場景中。本文介紹幾個查看Redis內(nèi)存信息的命令,包括常用的info memory、info keyspace、bigkeys等。
    2020-09-09
  • Redis過期刪除策略與內(nèi)存淘汰策略

    Redis過期刪除策略與內(nèi)存淘汰策略

    這篇文章主要介紹了Redis過期刪除策略與內(nèi)存淘汰策略,文章圍繞主題展開詳細的內(nèi)容戒殺,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • Redis中的3種特殊數(shù)據(jù)結構詳解

    Redis中的3種特殊數(shù)據(jù)結構詳解

    在本文中,我們對三種特殊的數(shù)據(jù)類型進行了介紹,它們分別是geospatial(地理空間數(shù)據(jù)類型)、HyperLogLogs和Bitmaps(位圖),這些數(shù)據(jù)類型在不同的領域和應用中發(fā)揮著重要作用,并且具有各自獨特的特性和用途,對Redis特殊數(shù)據(jù)結構相關知識感興趣的朋友一起看看吧
    2024-02-02
  • 為啥懶 Redis 是更好的 Redis

    為啥懶 Redis 是更好的 Redis

    本文是由zicode, 李中凱, 無若翻譯的英文文章Lazy Redis is better Redis,小編認為非常不錯,這里推薦給大家
    2018-07-07
  • 詳解Redis用鏈表實現(xiàn)消息隊列

    詳解Redis用鏈表實現(xiàn)消息隊列

    Redis有兩種方式實現(xiàn)消息隊列,一種是用Redis自帶的鏈表數(shù)據(jù)結構,另一種是用Redis發(fā)布/訂閱模式實現(xiàn),這篇文章先介紹鏈表實現(xiàn)消息隊列,有需要的朋友們可以參考借鑒。
    2016-09-09
  • Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer區(qū)別

    Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializ

    本文主要介紹了Jackson2JsonRedisSerializer和GenericJackson2JsonRedisSerializer區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • 詳解Redis如何保證接口的冪等性

    詳解Redis如何保證接口的冪等性

    如何防止接口中同樣的數(shù)據(jù)提交,以及如何保證消息不被重復消費,這些都是shigen在學習的過程中遇到的問題,今天,趁著在學習redis的間隙,我寫了一篇文章進行簡單的實現(xiàn),需要的朋友可以參考下
    2023-11-11

最新評論