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