python---redis管道(事务)和发布订阅

Redis管道与发布订阅机制
本文介绍了Redis中的管道和发布订阅功能,详细解释了管道如何提高数据操作效率,以及发布订阅如何实现消息传递。通过代码示例展示了这两种功能的具体用法。

管道:将数据操作放在内存中,只有成功后,才会一次性全部放入redis

#管道(事务),要是都成功则成功,失败一个全部失败
#原理:将数据操作放在内存中,只有成功后,才会一次性全部放入redis
pipe = r.pipeline(transaction=True)

pipe.set('name','sad')
pipe.set('age',20)

pipe.execute()

发布订阅:(回顾:查看rabbitMQ订阅者模式,这个功能更加强大)

基础类:将订阅和发送集合到一个类中了

import redis

#将订阅和发送集合到一个类中了
class RedisHelper:
    def __init__(self):
        self.__conn = redis.Redis(host="localhost",port=6379)#默认端口也是6379
        self.chan_sub = "fm104.5"#接收的波段
        self.chan_pub = "fm104.5"#发送的波段

    #发布消息
    def public(self,msg):
        self.__conn.publish(self.chan_pub,msg)
        return True

    #订阅消息
    def subscribe(self):
        pub = self.__conn.pubsub()
        pub.subscribe(self.chan_sub)
        pub.parse_response()
        return pub

发布者:

一:不使用基础类直接发布

import redis


r = redis.Redis(host="127.0.0.1")
r.publish("fm104.5","dasfa")

二:使用基础类发布

from base import RedisHelper


obj = RedisHelper()
obj.public("hello")

订阅者:

一:不使用基础类:

import redis


r = redis.Redis(host="127.0.0.1")
pub = redis.pubsub()      #定义订阅者
pub.subscribe(fm104.5)#定义其接受频段 
msg = pub.parse_response() #开始接受
print(msg)

二:使用基础类:

obj = RedisHelper()
redis_sub = obj.subscribe()

while True:
    msg = redis_sub.parse_response()
    print(msg)   #[b'message', b'fm104.5', b'hello']

继承类更加方便使用

转载于:https://www.cnblogs.com/ssyfj/p/8612850.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值