先介绍一下redis的pub/sub功能:
Pub/Sub功能(means Publish, Subscribe)即发布及订阅功能。基于事件的系统中,Pub/Sub是目前广泛使用的通信模型,它采用事件作为基本的通信机制,提供大规模系统所要求的松散耦合的交互模式:订阅者(如客户端)以事件订阅的方式表达出它有兴趣接收的一个事件或一类事件;发布者(如服务器)可将订阅者感兴趣的事件随时通知相关订阅者。
通俗来讲,就是说我sub端(订阅者)一直监听着,一旦pub端(发布者)发布了消息,那么我就接收过来,举个例子,先是发布者:
1
2
3
4
5
6
7
8
9
10
11
|
#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) #发布消息到liao |
接着我们来看看订阅者:
1
2
3
4
5
6
7
8
9
10
11
|
#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(): #监听状态:有消息发布了就拿过来 if item[ 'type' ] = = 'message' : print item[ 'channel' ] print item[ 'data' ] |
关于数据结构,也就是item,是类似于:{'pattern': None, 'type': 'message', 'channel': 'liao', 'data': '300033 1'}这样的,所以可以通过channel来判断这个消息是属于哪一个队列里的。(运行程序的时候,先运行订阅者,在运行发布者程序)
总结,要点有两个:
- 一是连接方式。使用python连接redis有三种方式:①使用库中的Redis类(或StrictRedis类,其实差不多);②使用ConnectionPool连接池(可保持长连接);③使用Sentinel类(如果有多个redis做集群时,程序会自己选择一个合适的连接)。
- 二是订阅方法。这里使用的是StrictRedis类中的pubsub方法。连接好之后,可使用subscribe或psubscribe方法来订阅redis消息。其中subscribe是订阅一个频道,psubscribe可订阅多个频道(这样写的时候,作为参数的频道应该是一个列表)。之后就可以开始监听了。
到此这篇关于python中sub-pub机制实现Redis的订阅与发布 的文章就介绍到这了,更多相关python Redis的订阅与发布 内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/liao392781/article/details/81180999