什么是Redis發(fā)布訂閱模式

本篇內(nèi)容主要講解“什么是redis發(fā)布訂閱模式”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“什么是Redis發(fā)布訂閱模式”吧!

創(chuàng)新互聯(lián)建站的客戶來自各行各業(yè),為了共同目標(biāo),我們在工作上密切配合,從創(chuàng)業(yè)型小企業(yè)到企事業(yè)單位,感謝他們對我們的要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。專業(yè)領(lǐng)域包括成都做網(wǎng)站、網(wǎng)站設(shè)計、電商網(wǎng)站開發(fā)、微信營銷、系統(tǒng)平臺開發(fā)。

發(fā)布/訂閱交互模式

角色關(guān)系:

  • 客戶端分為發(fā)布者和訂閱者兩種角色

  • 發(fā)布者和訂閱者通過channel關(guān)聯(lián)

交互方向:

  • 發(fā)布者和Redis服務(wù)器的交互仍為請求/響應(yīng)模式

  • 服務(wù)器向訂閱者發(fā)送數(shù)據(jù)(推送)

  • 時序:推送發(fā)送在服務(wù)器收到發(fā)布者消息之后

兩類channel

  • 普通channel:訂閱者通過SUBSCRIBE/UNSUBSCRIBE將自己綁定/解綁到某個Channel上;發(fā)布者的publish命令指定某個消息發(fā)送到哪個channel,再由服務(wù)器將消息轉(zhuǎn)發(fā)給channel上綁定的訂閱者

  • pattern channel:訂閱者通過PSUBSCRIBE/PUNSUBSCRIBE將自己綁定/解綁到某個pattern channel上;發(fā)布者的publish命令指定某個消息發(fā)送到哪個channel,再由服務(wù)器通過channel的名字和pattern channel的名字做匹配,匹配成功則將消息轉(zhuǎn)發(fā)給這個pattern channel上綁定的訂閱者。

訂閱關(guān)系的實現(xiàn)

channel的訂閱關(guān)系,維護在Redis實例級別,獨立于redisDb的key-value體系。

  
    
  
  
  typedef struct redisServer{    ...    dict *pubsub_channels;    dict *pubsub_patterns;    ...}

pubsub_channels map維護普通channel和訂閱者的關(guān)系:鍵是channel的名字,value是它所有訂閱者client的指針鏈表

pubsub_patterns維護pattern channel和訂閱者的關(guān)系:鏈表的每個元素包含兩部分(pattern channel的名字和訂閱它的client指針)

發(fā)布者向某個channel publish一條消息時,redis首先會從pubsub_channels中找到對應(yīng)的value,向它的所有client發(fā)送該消息;同時,遍歷pubsub_patterns列表,向能夠匹配的元素的client也發(fā)送該消息。

到此,相信大家對“什么是Redis發(fā)布訂閱模式”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

網(wǎng)頁題目:什么是Redis發(fā)布訂閱模式
網(wǎng)站URL:http://bm7419.com/article44/jjdpee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、網(wǎng)站內(nèi)鏈、動態(tài)網(wǎng)站、全網(wǎng)營銷推廣、App開發(fā)品牌網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計公司