麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > Redis > 正文

redis發布訂閱_動力節點Java學院整理

2020-03-17 12:37:04
字體:
來源:轉載
供稿:網友

其實在很多的MQ產品中都存在這樣的一個模式,我們常聽到的一個例子就是郵件訂閱的場景,什么意思呢,也就是說100個人訂閱了你的博客,如果博主發表了文章,那么100個人就會同時收到通知郵件,除了這個場景還能找到其他場景么,當然有啦,你想想,如果你要在內存里面做一個讀寫分離的程序,為了維持數據的完整性,你是不是需要保證在寫入的時候,也要分發到各個讀內存的程序中呢?所以說場景還是很多的,在于你的挖掘~~~ 下面還是從基本命令入手:

一:命令簡介

redis發布訂閱,redis,發布訂閱命令

從redis手冊上面可以看到,其實“發布、訂閱”模式才區區6個命令,下面聽我一一解說下哈~~~

1. subscribe

SUBSCRIBE channel [channel ...]

訂閱給定的一個或多個頻道的信息。     

從上面的官方解釋上來看,它的玩法有一點像現實生活中我們聽收音機一個道理,要想聽收音機,我們要做什么?肯定就是調頻啦,只有在正確的頻道上面,我們才能聽得到好聽的節目,所以說subscribe首先要訂閱一個頻道(channel),下面我舉個例子,開兩個client,分別訂閱著msg 這個頻道,比如下面這樣:

redis發布訂閱,redis,發布訂閱命令

2.publish  

到現在為止,這兩個subscibe都在監視著msg這個頻道,接下來,如果msg頻道有消息傳出,必定會被subscribe接收到,先我們還是看看redis手冊上怎么用這個命令。

PUBLISH channel message

將信息 message 發送到指定的頻道 channel 。

看到上面命令的用法,我也就放心了。

redis發布訂閱,redis,發布訂閱命令

看到么有,publish在msg這個頻道上面發送消息后,被subscribe監視到了,然后就被分別打印輸出了,好了,到現在為止,最基本的發布訂閱模式就是這樣,是不是很簡單哈。。。其實呢??? 也就是這么簡單吶,但是呢,有時候我們還有這樣一個需求,就是我能不能模糊匹配key呢???舉了例子,就是要求訂閱china為前綴的所有頻道,如果這樣也可以做到的話,那確實是很牛啦。。。強大的redis自然會做到這一點,它提供了的命令就是:Psubscribe。

3. Psubscribe

PSUBSCRIBE pattern [pattern ...]

訂閱一個或多個符合給定模式的頻道。

每個模式以 * 作為匹配符,比如 it* 匹配所有以 it 開頭的頻道( it.news 、 it.blog 、 it.tweets 等等), news.* 匹配所有以 news. 開頭的頻道( news.it 、 news.global.today 等等),諸如此類。

看到上面的解釋,你心里可能就在想,這不就是正則匹配么。。。而且前綴“P”就是Pattern的意思,對吧,接下來我就訂閱一下所有china為前綴的channel。

redis發布訂閱,redis,發布訂閱命令

好了,最常用的也就是這三個命令,接下來我們簡單分析一下代碼。

二: 源碼簡單分析

其實redis的發布訂閱模式,使用RedisServer下面的 pubsub_channels字典 和 pubsub_patterns數組存放的,所有的操作代碼都

在pubsub.c文件下,如下圖:

redis發布訂閱,redis,發布訂閱命令

1.   pubsub_channels 

可以看到,它是一個字典結構,通過注釋你應該明白,它的key為channel,value為list。

2.   pubsub_patterns

同樣從注釋中,你可以看到,其實它就是存放模式匹配的subscribe的clients列表,對吧,用一個list數組實現。 

3.   subcribeCommand

通過下面的代碼,你是不是在腦子里面很有輪廓了???其實這個pubsub_channels果然就是key=channel,value=list的存放模式,這個list就是所謂的clients列表,這樣的話,你就知道了哪些key掛了哪些clients,對吧,如果再publish的話,只需要遍歷一下這個list就知道結果了。

redis發布訂閱,redis,發布訂閱命令

4.  publishCommand

先前也說了,publish的原理很簡單,就是找到字典中的channel這個key,獲取到clients之后,遍歷client的來發送信息。

redis發布訂閱,redis,發布訂閱命令

同樣的道理,pubsub_patterns也是差不多的實現,只要大家簡單看一下pubsub.c這個源代碼文件,差不多都會懂得


注:相關教程知識閱讀請移步到Redis頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 视频一区二区三区在线观看 | 末成年女av片一区二区 | 国产高潮好爽受不了了夜色 | 一二区成人影院电影网 | v11av在线播放 | 久久综合久久美利坚合众国 | 黄色网址免费入口 | 美国av在线免费观看 | 久久中文一区 | 国产精品亚洲综合 | 免费网址黄 | 精品一区二区电影 | 国产毛片在线看 | 宅男噜噜噜66国产免费观看 | 红杏网站永久免费视频入口 | 久久久一区二区 | 欧美精品在线视频观看 | 欧美www| 91精品久久久久久久 | 亚洲欧洲av在线 | 337p日本欧洲亚洲大胆精蜜臀 | 国产成年人视频 | 亚洲一区二区在线免费 | 精品国产视频一区二区三区 | 成人免费福利网站 | 午夜精品久久久久久中宇 | 欧美aⅴ视频| 午夜啪视频 | 中文黄色一级片 | 成人短视频在线观看 | 1314成人网| 国产a一级片 | 91一区二区在线观看 | 国产精品9191 | 99国产精品国产免费观看 | 中国性xxx| 国产成人综合在线观看 | 爱看久久 | 成人午夜小视频 | 一级做受毛片免费大片 | 国产一区精品在线观看 |