python中sub-pub機制實現(xiàn)Redis的訂閱與發(fā)布
先介紹一下redis的pub/sub功能:
Pub/Sub功能(means Publish, Subscribe)即發(fā)布及訂閱功能?;谑录南到y(tǒng)中,Pub/Sub是目前廣泛使用的通信模型,它采用事件作為基本的通信機制,提供大規(guī)模系統(tǒng)所要求的松散耦合的交互模式:訂閱者(如客戶端)以事件訂閱的方式表達出它有興趣接收的一個事件或一類事件;發(fā)布者(如服務器)可將訂閱者感興趣的事件隨時通知相關訂閱者。
通俗來講,就是說我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']
關于數(shù)據(jù)結構,也就是item,是類似于:{'pattern': None, 'type': 'message', 'channel': 'liao', 'data': '300033 1'}這樣的,所以可以通過channel來判斷這個消息是屬于哪一個隊列里的。(運行程序的時候,先運行訂閱者,在運行發(fā)布者程序)
總結,要點有兩個:
- 一是連接方式。使用python連接redis有三種方式:①使用庫中的Redis類(或StrictRedis類,其實差不多);②使用ConnectionPool連接池(可保持長連接);③使用Sentinel類(如果有多個redis做集群時,程序會自己選擇一個合適的連接)。
- 二是訂閱方法。這里使用的是StrictRedis類中的pubsub方法。連接好之后,可使用subscribe或psubscribe方法來訂閱redis消息。其中subscribe是訂閱一個頻道,psubscribe可訂閱多個頻道(這樣寫的時候,作為參數(shù)的頻道應該是一個列表)。之后就可以開始監(jiān)聽了。
到此這篇關于python中sub-pub機制實現(xiàn)Redis的訂閱與發(fā)布 的文章就介紹到這了,更多相關python Redis的訂閱與發(fā)布 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
VSCode基礎使用與VSCode調試python程序入門的圖文教程
這篇文章主要介紹了VSCode基礎使用+VSCode調試python程序入門圖文教程,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03
Python中字符串類型代碼的執(zhí)行函數(shù)——eval()、exec()和compile()詳解
這篇文章主要介紹了Python中字符串類型代碼的執(zhí)行函數(shù)——eval()、exec()和compile(),字符串類型代碼的執(zhí)行函數(shù)有三個,都是Python的內(nèi)置函數(shù),下面逐一對這三個函數(shù)詳細講解,需要的朋友可以參考下2023-02-02
Python 網(wǎng)頁解析HTMLParse的實例詳解
這篇文章主要介紹了Python 網(wǎng)頁解析HTMLParse的實例詳解的相關資料,python里提供了一個簡單的解析模塊HTMLParser類,使用起來也是比較簡單的,解析語法沒有用到XPath類似的簡潔模式,需要的朋友可以參考下2017-08-08
python一行代碼就能實現(xiàn)數(shù)據(jù)分析的pandas-profiling庫
這篇文章主要為大家介紹了python一行代碼就能實現(xiàn)數(shù)據(jù)分析的pandas-profiling庫,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2024-01-01
詳解Python+Selenium+ChromeDriver的配置和問題解決
這篇文章主要介紹了Python+Selenium+ChromeDriver的配置和問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01

