python中sub-pub機(jī)制實(shí)現(xiàn)Redis的訂閱與發(fā)布
先介紹一下redis的pub/sub功能:
Pub/Sub功能(means Publish, Subscribe)即發(fā)布及訂閱功能?;谑录南到y(tǒng)中,Pub/Sub是目前廣泛使用的通信模型,它采用事件作為基本的通信機(jī)制,提供大規(guī)模系統(tǒng)所要求的松散耦合的交互模式:訂閱者(如客戶端)以事件訂閱的方式表達(dá)出它有興趣接收的一個(gè)事件或一類事件;發(fā)布者(如服務(wù)器)可將訂閱者感興趣的事件隨時(shí)通知相關(guān)訂閱者。
通俗來講,就是說我sub端(訂閱者)一直監(jiān)聽著,一旦pub端(發(fā)布者)發(fā)布了消息,那么我就接收過來,舉個(gè)例子,先是發(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來判斷這個(gè)消息是屬于哪一個(gè)隊(duì)列里的。(運(yùn)行程序的時(shí)候,先運(yùn)行訂閱者,在運(yùn)行發(fā)布者程序)
總結(jié),要點(diǎn)有兩個(gè):
- 一是連接方式。使用python連接redis有三種方式:①使用庫中的Redis類(或StrictRedis類,其實(shí)差不多);②使用ConnectionPool連接池(可保持長連接);③使用Sentinel類(如果有多個(gè)redis做集群時(shí),程序會自己選擇一個(gè)合適的連接)。
- 二是訂閱方法。這里使用的是StrictRedis類中的pubsub方法。連接好之后,可使用subscribe或psubscribe方法來訂閱redis消息。其中subscribe是訂閱一個(gè)頻道,psubscribe可訂閱多個(gè)頻道(這樣寫的時(shí)候,作為參數(shù)的頻道應(yīng)該是一個(gè)列表)。之后就可以開始監(jiān)聽了。
到此這篇關(guān)于python中sub-pub機(jī)制實(shí)現(xiàn)Redis的訂閱與發(fā)布 的文章就介紹到這了,更多相關(guān)python Redis的訂閱與發(fā)布 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python調(diào)用http-post接口的實(shí)現(xiàn)方式
這篇文章主要介紹了Python調(diào)用http-post接口的實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
Pytorch使用VGG16模型進(jìn)行預(yù)測貓狗二分類實(shí)戰(zhàn)
VGG16是Visual Geometry Group的縮寫,它的名字來源于提出該網(wǎng)絡(luò)的實(shí)驗(yàn)室,本文我們將使用PyTorch來實(shí)現(xiàn)VGG16網(wǎng)絡(luò),用于貓狗預(yù)測的二分類任務(wù),我們將對VGG16的網(wǎng)絡(luò)結(jié)構(gòu)進(jìn)行適當(dāng)?shù)男薷?以適應(yīng)我們的任務(wù),需要的朋友可以參考下2023-08-08
python基于物品協(xié)同過濾算法實(shí)現(xiàn)代碼
這篇文章主要為大家詳細(xì)介紹了python基于物品協(xié)同過濾算法實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05
基于文件路徑中/?\?//?\\的用法以及絕對相對路徑的問題
這篇文章主要介紹了基于文件路徑中/?\?//?\\的用法以及絕對相對路徑的問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02
python引入導(dǎo)入自定義模塊和外部文件的實(shí)例
下面小編就為大家?guī)硪黄猵ython引入導(dǎo)入自定義模塊和外部文件的實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07

