首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >通过python实现Redis的订阅与发布

通过python实现Redis的订阅与发布

作者头像
SEian.G
发布2021-03-03 10:01:30
发布2021-03-03 10:01:30
1.8K00
代码可运行
举报
文章被收录于专栏:SEian.G学习记录SEian.G学习记录
运行总次数:0
代码可运行
在前面的一篇文章中已经介绍了

Pub/Sub功能(means Publish, Subscribe)即发布及订阅功能。基于事件的系统中,Pub/Sub是目前广泛使用的通信模型,它采用事件作为基本的通信机制,提供大规模系统所要求的松散耦合的交互模式;

订阅者(如客户端)以事件订阅的方式表达出它有兴趣接收的一个事件或一类事件;

发布者(如服务器)可将订阅者感兴趣的事件随时通知相关订阅者。

通俗来讲,就是说我sub端(订阅者)一直监听着,一旦pub端(发布者)发布了消息,那么我就接收过来,举个例子,先是发布者:

前提说明:由于下面才是的redis实例是腾讯云的redis实例,腾讯云Redis 2.8主从版实例的认证方式是实例id:密码的方式;

代码语言:javascript
代码运行次数:0
运行
复制
#coding:utf-8
import redis
 
host = '10.66.XX.XX' 
port = 6379 
user='crs-pte25qxx' 
pwd='XXXXXX'  
 
number_list = ['300033', '300032', '300031', '300030']
signal = ['1', '-1', '1', '-1']
 
rc = redis.Strict<a href="http://www.seiang.com/?tag=redis" title="查看更多关于Redis的文章" target="_blank">Redis</a>(host=host, port=port, password=user+':'+pwd)
 
for i in range(len(number_list)):
    value_new = str(number_list[i]) + ' ' + str(signal[i])
    rc.publish("wjq", value_new)

接着我们来看看订阅者:

代码语言:javascript
代码运行次数:0
运行
复制
#coding:utf-8
import redis
 
host = '10.66.XX.XX' 
port = 6379 
user='crs-pte25qxx' 
pwd='XXXXXX'  
 
rc = redis.Strict<a href="http://www.seiang.com/?tag=redis" title="查看更多关于Redis的文章" target="_blank">Redis</a>(host=host, port=port, password=user+':'+pwd)
ps = rc.pubsub()
ps.subscribe('wjq') 
for item in ps.listen(): 
    if item['type'] == 'message':
        print item['channel']
        print item['data']

注意:这里运行程序的时候先运行订阅者,在运行发布者程序 关于数据结构,也就是item变量,类似于:{‘pattern’: None, ‘type’: ‘message’, ‘channel’: ‘wjq’, ‘data’: ‘3000331’}这样的,所以可以通过channel来判断这个消息是属于哪一个队列里的。

针对上面的代码解释两点: 1、连接方式;使用python连接redis有三种方式: ①使用库中的Redis类(或StrictRedis类,其实差不多); ②使用ConnectionPool连接池(可保持长连接); ③使用Sentinel类(如果有多个redis做集群时,程序会自己选择一个合适的连接)。

2、订阅方法;这里使用的是StrictRedis类中的pubsub方法。连接好之后,可使用subscribe或psubscribe方法来订阅redis消息。其中subscribe是订阅一个频道,psubscribe可订阅多个频道(这样写的时候,作为参数的频道应该是一个列表),之后就可以开始监听了

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-03-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 DBA的辛酸事儿 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档