Redis PUBLISH命令

yizhihongxing

Redis的PUBLISH命令用于向指定的频道(channel)发布一条消息(message),所有订阅该频道的客户端都能接收到这条消息。其基本格式为:PUBLISH channel message。

PUBLISH命令是Redis发布/订阅(pub/sub)功能的基础命令之一,常用于实现聊天室、实时消息推送等场景。下面就来详细讲解它的使用方法及示例:

标题

命令格式

PUBLISH channel message

参数说明

  • channel:要发布消息的频道名称。
  • message:要发布的消息内容。

使用方法

  1. 在Redis-cli客户端中使用PUBLISH命令,例如向名为“chat_room”的频道发布一条“Hello World!”的消息:
PUBLISH chat_room "Hello World!"
  1. 也可以在程序中使用Redis的客户端库,比如Python的redis模块,实现PUBLISH命令的调用,如下所示:
import redis
r = redis.Redis(host='localhost', port=6379, decode_responses=True)
r.publish('chat_room', 'Hello World!')

示例说明

  1. 聊天室实现
    假设有一个在线聊天室,多个用户可以在该聊天室中发送和接收消息,那么在聊天室服务器中,可以通过调用PUBLISH命令将用户输入的消息实时广播到所有订阅了该频道的客户端中:
// 服务器端
import redis
import asyncio

async def handle(reader, writer):
    addr = writer.get_extra_info('peername')
    print('Accepted connection from {}'.format(addr))
    p = await redis.ConnectionPool.create(host='localhost', port=6379, db=0)
    r = redis.Redis(connection_pool=p)
    channel = 'chat_room'
    while True:
        data = await reader.read(1024)
        message = data.decode('utf-8').strip()
        if not message:
            break
        r.publish(channel, message)
    print('Close the client socket')
    writer.close()

async def main():
    server = await asyncio.start_server(handle, 'localhost', 8888)
    addr = server.sockets[0].getsockname()
    print(f'Serving on {addr}')
    async with server:
        await server.serve_forever()

asyncio.run(main())
// 客户端
import asyncio
import sys

async def tcp_echo_client():
    reader, writer = await asyncio.open_connection('localhost', 8888)

    while True:
        message = input("> ")
        if not message:
            break
        writer.write(message.encode())
        await writer.drain()

    print('Close the socket')
    writer.close()
    await writer.wait_closed()

async def main():
    await tcp_echo_client()

asyncio.run(main())

多个客户端连接到服务器后,输入的消息将被实时发布到订阅了该频道的其他客户端中。

  1. 实时数据更新
    比如一个在线商城,当有商品库存更新时,需要及时通知所有客户端,可以通过调用PUBLISH命令实现该功能:
import redis
import time

r = redis.Redis(host='localhost', port=6379, decode_responses=True)
channel = 'product_update'
while True:
    # 假设每隔5秒自动刷新一次页面,查询库存
    stock = query_stock()
    r.publish(channel, stock)
    time.sleep(5)

在客户端中订阅该频道,就可以实时接收到商品库存的变化信息,从而及时更新页面数据。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Redis PUBLISH命令 - Python技术站

(0)
上一篇 2023年3月28日
下一篇 2023年3月28日

相关文章

  • Zabbix 监控PHP-FTPM、Tomcat、Redis应用

    一、zabbix 监控 PHP-FPM应用实战Nginx+PHP-FPM是目前最流行的LNMP架构,在基于PHP开发的系统下,对这些系统性能的监控,主要是关注PHP-FPM的运行状态,那么什么是PHP-FPM呢,我们说PHP-FPM(FastCGI Process Manager:FastCGI进程管理器)是一个PHP FastCGI管理器,它提供了更好的P…

    Redis 2023年4月11日
    00
  • Redis Command

    键值操作 get key set key value incr key decr key del key [key …] rename key newkey renamenx key newkey keys pattern incrby key increment incrbyfloat key increment append key value de…

    Redis 2023年4月9日
    00
  • LNMP+Redis架构部署

    L(Linux)N(Nginx)M(Mysql)P(PHP)架构想必大家都知道,LNMP架构主要作用是让前端服务与后端存储以及后端的一下服务进行连接起来,来实现php程序的动态请求。    而今天我们又在LNMP架构上面加一个Redis程序,而Redis在整个架构中起到了一个数据缓存的作用。 LNMP+Redis工作机制:当用户通过浏览器访问网站时,并使用账…

    Redis 2023年4月13日
    00
  • Redis集群介绍及测试思路

    Redis集群一般有四种方式,分别为:主从复制、哨兵模式、Cluster以及各大厂的集群方案。在3.0版本之前只支持单实例模式,3.0之后支持了集群方式。在3.0之前各大厂为了解决单实例Redis的存储瓶颈问题各自推出了自己的集群方案,其核心思想就是数据分片,主要有客户端分片、代理分片、服务端分片。这里咱们只介绍前三种方式:主从、哨兵、Cluster。 作者…

    2023年4月10日
    00
  • redis-cluster的实例动态调整内存

    当redis.conf中的最大内存配置为10G的时候,恰好程序已经写满了,但是物理主机是有内存的, 此时可以通过config set xxxx xxxx 来设置实例的内存大小,而不需要重启实例。   获取当前最大内存的大小: config get maxmemory   修改内存大小: config set maxmemory 32212254720   有…

    Redis 2023年4月11日
    00
  • SpringBoot进阶教程(五十五)整合Redis之分布式锁

    在之前的一篇文章(《Java分布式锁,搞懂分布式锁实现看这篇文章就对了》),已经介绍过几种java分布式锁,今天来个Redis分布式锁的demo。redis 现在已经成为系统缓存的必备组件,针对缓存读取更新操作,通常我们希望当缓存过期之后能够只有一个请求去更新缓存,其它请求依然使用旧的数据。这就需要用到锁,因为应用服务多数以集群方式部署,因此这里的锁就必需要…

    Redis 2023年4月13日
    00
  • day02-Redis命令

    Redis命令 1.Redis数据结构介绍 Redis是一个key-value的数据库,key一般是String类型,value的类型多种多样,value常见的八种类型: Redis支持五种基本的数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set,有序集合)。 各个数据类型应用场景: 类型 简…

    2023年4月16日
    00
  • Springboot整合redis步骤

    <dependency> <groupId>com.github.spt-oss</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> <version>2.0.7.0</version> <…

    Redis 2023年4月16日
    00
合作推广
合作推广
分享本页
返回顶部