python实现 redis订阅与发布

本文涉及的产品
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介:

  订阅者可以订阅一个或多个频道,发布者向一个频道发送消息后,所有订阅这个频道的订阅者都将收到消息,而发布者也将收到一个数值,这个数值是收到消息的订阅者的数量。订阅者只能收到自它开始订阅后发布者所发布的消息,之前发布的消息呢,就不可能收到了。

                                           多的不说看代码!!!

面向过程的方法

#!/usr/bin/python

#coding:utf-8


#服务器端

import redis  

r = redis.Redis(host='127.0.0.1',port='6379') #连接redis

p = r.pubsub()        #开启订阅

p.subscribe('6379')  #接收订阅的数据,订阅的频道 


for item in p.listen():  #读取接收的数据

    print item 

    if item['type'] == 'message': #判断数据是否是用户发布的数据   

        data = item['data']      #取出用户要发布的数据

        print data   #打印要发布的数据


        if item['data'] == 'Q' or item['data'] == 'q':    

            break;       #退出程序

p.unsubscribe('6379') #关闭频道  

print '取消订阅'


#客户端

#!/usr/bin/py

#coding:utf-8

import redis  

r = redis.Redis(host='127.0.0.1',port=6379) #连接redis

  

while True:  

    my_input = raw_input("请输入发布内容:") #输入发布的内容  

    r.publish('6379', my_input) #发送到的频道,发布的内容   


    if my_input == 'Q' or my_input == 'q':       #判断用户是否要退出程序

        print '停止发布'  

        break; 


面向对象的方法

#服务器端

#!/usr/bin/python

#coding:utf-8

import redis


class server(object):

    def __init__(self,ip='127.0.0.1',port=6379,sub='A'):

        self.ip = ip

        self.port = port

        self.connect = redis.Redis(host=self.ip,port=self.port)   #连接redis

        self.sub = sub  #监听频道

    def se(self):

        spub = self.connect.pubsub() #打开订阅

        spub.subscribe(self.sub) #开始监听

        spub.listen() #用户发布的数据

        return spub


x = server()

p = x.se()

for item in p.listen():     #打印接收到的数据

    print item


#客户端

#!/usr/bin/python

#coding:utf-8

import redis


class client(object):

    def __init__(self,ip='127.0.0.1',port=6379,pub='A'):

        self.ip = ip

        self.port = port

        self.connect = redis.Redis(host=self.ip,port=self.port)

        self.pub = pub         #连接的频道

    def cl(self,content):

        self.connect.publish(self.pub,content) #频道,发送的数据


x = client()

while True:

    my_input = raw_input('请输入发布内容:')     #发布的数据

    x.cl(my_input)


        个人比较喜欢第二种方法,也推荐各位朋友使用第二种方法,第二种方法中我没有对接收到的数据进行过多的处理,如果各位朋友喜欢可以拿去自行修改

本文转自  红尘世间  51CTO博客,原文链接:http://blog.51cto.com/hongchen99/1909790

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
3月前
|
消息中间件 NoSQL PHP
Laravel实现redis发布-订阅
Laravel实现redis发布-订阅
26 0
|
4月前
|
存储 NoSQL Redis
Redis 简介 + Python 操作发布订阅
Redis 简介 + Python 操作发布订阅
|
6天前
|
NoSQL MongoDB Redis
Python与NoSQL数据库(MongoDB、Redis等)面试问答
【4月更文挑战第16天】本文探讨了Python与NoSQL数据库(如MongoDB、Redis)在面试中的常见问题,包括连接与操作数据库、错误处理、高级特性和缓存策略。重点介绍了使用`pymongo`和`redis`库进行CRUD操作、异常捕获以及数据一致性管理。通过理解这些问题、易错点及避免策略,并结合代码示例,开发者能在面试中展现其技术实力和实践经验。
126 8
Python与NoSQL数据库(MongoDB、Redis等)面试问答
|
1月前
|
存储 JSON NoSQL
Redis与Python的完美结合:实现高效数据交互和应用场景全解析
Redis与Python的完美结合:实现高效数据交互和应用场景全解析
115 0
|
1月前
|
存储 NoSQL Redis
如何在Python中操作Redis数据库
如何在Python中操作Redis数据库
29 0
|
1月前
|
NoSQL Redis Python
python flask 使用 redis 写一个例子给我
python flask 使用 redis 写一个例子给我
38 4
|
2月前
|
缓存 NoSQL Redis
如何在Python中使用Redis或Memcached进行缓存?
如何在Python中使用Redis或Memcached进行缓存?
28 2
|
3月前
|
NoSQL Redis 数据库
python编写一个redis工具类
python编写一个redis工具类
146 0
|
NoSQL Redis Python
Redis与Python进行交互
安装包 安装Redis的有3种方式https://github.com/andymccurdy/redis-py 第一种:进⼊虚拟环境,联⽹安装包redis pip install redis 第二种:进⼊虚拟环境,联⽹安装包redis easy_install redis 第三种:到...
1543 0
|
15天前
|
NoSQL Linux Redis
06- 你们使用Redis是单点还是集群 ? 哪种集群 ?
**Redis配置:** 使用哨兵集群,结构为1主2从,加上3个哨兵节点,总计分布在3台Linux服务器上,提供高可用性。
221 0

热门文章

最新文章