溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python中sub-pub機制怎么實現(xiàn)Redis的訂閱與發(fā)布

發(fā)布時間:2023-05-10 15:50:03 來源:億速云 閱讀:291 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“python中sub-pub機制怎么實現(xiàn)Redis的訂閱與發(fā)布”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

先介紹一下redis的pub/sub功能:

Pub/Sub功能(means Publish, Subscribe)即發(fā)布及訂閱功能?;谑录南到y(tǒng)中,Pub/Sub是目前廣泛使用的通信模型,它采用事件作為基本的通信機制,提供大規(guī)模系統(tǒng)所要求的松散耦合的交互模式:訂閱者(如客戶端)以事件訂閱的方式表達出它有興趣接收的一個事件或一類事件;發(fā)布者(如服務(wù)器)可將訂閱者感興趣的事件隨時通知相關(guān)訂閱者。

通俗來講,就是說我sub端(訂閱者)一直監(jiān)聽著,一旦pub端(發(fā)布者)發(fā)布了消息,那么我就接收過來,舉個例子,先是發(fā)布者:

#coding:utf-8
import time
import redis
 
number_list = ['300033', '300032', '300031', '300030']
signal = ['1', '-1', '1', '-1']
 
rc = redis.StrictRedis(host='***', port='6379', db=3, password='********')
for i in range(len(number_list)):
    value_new = str(number_list[i]) + ' ' + str(signal[i])
    rc.publish("liao", value_new)  #發(fā)布消息到liao

接著我們來看看訂閱者:

#coding:utf-8
import time
import redis
 
rc = redis.StrictRedis(host='****', port='6379', db=3, password='******')
ps = rc.pubsub()
ps.subscribe('liao')  #從liao訂閱消息
for item in ps.listen():        #監(jiān)聽狀態(tài):有消息發(fā)布了就拿過來
    if item['type'] == 'message':
        print item['channel']
        print item['data']

關(guān)于數(shù)據(jù)結(jié)構(gòu),也就是item,是類似于:{'pattern': None, 'type': 'message', 'channel': 'liao', 'data': '300033 1'}這樣的,所以可以通過channel來判斷這個消息是屬于哪一個隊列里的。(運行程序的時候,先運行訂閱者,在運行發(fā)布者程序)

總結(jié),要點有兩個:

  • 一是連接方式。使用python連接redis有三種方式:①使用庫中的Redis類(或StrictRedis類,其實差不多);②使用ConnectionPool連接池(可保持長連接);③使用Sentinel類(如果有多個redis做集群時,程序會自己選擇一個合適的連接)。

  • 二是訂閱方法。這里使用的是StrictRedis類中的pubsub方法。連接好之后,可使用subscribe或psubscribe方法來訂閱redis消息。其中subscribe是訂閱一個頻道,psubscribe可訂閱多個頻道(這樣寫的時候,作為參數(shù)的頻道應(yīng)該是一個列表)。之后就可以開始監(jiān)聽了。

“python中sub-pub機制怎么實現(xiàn)Redis的訂閱與發(fā)布”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI