Python -- Redis 發布訂閱


參考博客:http://www.runoob.com/redis/redis-pub-sub.html

一、前言

  Redis 發布訂閱(pub/sub)是一種消息通信模式:發送者(pub)發送消息,訂閱者(sub)接收消息。

  Redis 客戶端可以訂閱任意數量的頻道。

  下圖展示了頻道 channel1 , 以及訂閱這個頻道的三個客戶端 —— client2 、 client5 和 client1 之間的關系:

  

  當有新消息通過 PUBLISH 命令發送給頻道 channel1 時, 這個消息就會被發送給訂閱它的三個客戶端:

  

二、事例

 Demo: 

import redis


class RedisHelper:

    def __init__(self):
        self.__conn = redis.Redis(host='172.16.200.49')
        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

  訂閱者:

# -*- coding: UTF-8 -*-

from redis_helper import RedisHelper

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

while True:
    msg = redis_sub.parse_response()
    print(msg)

  發布者:

# -*- coding: UTF-8 -*-

from redis_helper import RedisHelper

obj = RedisHelper()
while True:
    msg = input('>>:')
    obj.public(msg)

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM