Redis发布订阅和应用场景

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Redis发布订阅和应用场景

发布订阅-应用场景

Pub/Sub 从字面上理解就是发布(Publish)与订阅(Subscribe),在Redis中,你可以设定对某一个key值进行消息发布及消息订阅,当一个key值上进行了消息发布后,所有订阅它的客户端都会收到相应的消息。

这一功能最明显的用法就是构建实时消息系统,比如普通的即时聊天,群聊等功能。

订阅某个channel的信息

发布信息到某个channel

简单的应用场景的话,以门户网站为例,当编辑更新了某推荐板块的内容后:

CMS发布清除缓存的消息到channel (推送者推送消息)

门户网站的缓存系统通过channel收到清除缓存的消息(订阅者收到消息),更新了推荐板块的缓存

Redis 发布订阅架构

Redis提供了发布订阅功能,可以用于消息的传输,Redis的发布订阅机制包括三个部分,发布者,订阅者和Channel

image.gif

    • 发布者和订阅者都是Redis客户端,Channel则为Redis服务器端,发布者将消息发送到某个的频道,订阅了这个频道的订阅者就能接收到这条消息。
    • Redis的这种发布订阅机制与基于主题的发布订阅类似,Channel相当于主题。

    Redis 发布订阅命令

    PSUBSCRIBE pattern [pattern ...]

    订阅一个或者多个符合模式匹配的频道

    假设客户端同时订阅了某种模式和符合该模式的某个频道,那么发送给这个频道的消息将被客户端接收到两次,只不过这两条消息的类型不同,一个是message类型,一个是pmessage类型,但其内容相同。

    PUBSUB subcommand [argument [argument ...]]

    返回由活跃频道组成的列表,即可以查询订阅与发布系统的状态

    PUBLISH channel message

    发送消息到指定的频道

    其返回值为接收到该消息的订阅者的数量

    SUBSCRIBE channel [channel ...] 

    订阅一个或多个频道

    其返回值包括客户端订阅的频道,目前已订阅的频道数量,以及接收到的消息,其中subscribe表示已经成功订阅了某个频道

    PUNSUBSCRIBE [pattern [pattern ...]] 

    退订所有符合模式匹配的频道

    UNSUBSCRIBE [channel [channel ...]] 

    退订一个或多个频道

    Redis采用UNSUBSCRIBE和PUNSUBSCRIBE命令取消订阅,其返回值与订阅类似。
    由于Redis的订阅操作是阻塞式的,因此一旦客户端订阅了某个频道或模式,就将会一直处于订阅状态直到退出。

    在SUBSCRIBE,PSUBSCRIBE,UNSUBSCRIBE和PUNSUBSCRIBE命令中,

    其返回值都包含了该客户端当前订阅的频道和模式的数量,当这个数量变为0时,该客户端会自动退出订阅状态。

    Redis发布订阅与ActiveMQ的比较

    1ActiveMQ支持多种消息协议,包括AMQPMQTTStomp等,并且支持JMS规范,但Redis没有提供对这些协议的支持

    2ActiveMQ提供持久化功能,但Redis无法对消息持久化存储,一旦消息被发送,如果没有订阅者接收,那么消息就会丢失;

    3ActiveMQ提供了消息传输保障,当客户端连接超时或事务回滚等情况发生时,消息会被重新发送给客户端,Redis没有提供消息传输保障

    总之,ActiveMQ所提供的功能远比Redis发布订阅要复杂,毕竟Redis不是专门做发布订阅的,

    但是如果系统中已经有了Redis,并且需要基本的发布订阅功能,就没有必要再安装ActiveMQ了,

    因为可能ActiveMQ提供的功能大部分都用不到,而Redis的发布订阅机制就能满足需求。

    参考来源:https://www.cnblogs.com/yitudake/p/6747995.html

    相关实践学习
    基于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
    数据的存储--Redis缓存存储(一)
    数据的存储--Redis缓存存储(一)
    117 1
    |
    14天前
    |
    存储 缓存 NoSQL
    解决Redis缓存数据类型丢失问题
    解决Redis缓存数据类型丢失问题
    157 85
    |
    3月前
    |
    存储 缓存 NoSQL
    数据的存储--Redis缓存存储(二)
    数据的存储--Redis缓存存储(二)
    53 2
    数据的存储--Redis缓存存储(二)
    |
    3月前
    |
    消息中间件 缓存 NoSQL
    Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。
    【10月更文挑战第4天】Redis 是一个高性能的键值对存储系统,常用于缓存、消息队列和会话管理等场景。随着数据增长,有时需要将 Redis 数据导出以进行分析、备份或迁移。本文详细介绍几种导出方法:1)使用 Redis 命令与重定向;2)利用 Redis 的 RDB 和 AOF 持久化功能;3)借助第三方工具如 `redis-dump`。每种方法均附有示例代码,帮助你轻松完成数据导出任务。无论数据量大小,总有一款适合你。
    85 6
    |
    11天前
    |
    缓存 监控 NoSQL
    Redis经典问题:缓存穿透
    本文详细探讨了分布式系统和缓存应用中的经典问题——缓存穿透。缓存穿透是指用户请求的数据在缓存和数据库中都不存在,导致大量请求直接落到数据库上,可能引发数据库崩溃或性能下降。文章介绍了几种有效的解决方案,包括接口层增加校验、缓存空值、使用布隆过滤器、优化数据库查询以及加强监控报警机制。通过这些方法,可以有效缓解缓存穿透对系统的影响,提升系统的稳定性和性能。
    |
    2月前
    |
    缓存 NoSQL 关系型数据库
    大厂面试高频:如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难题
    本文详解缓存雪崩、缓存穿透、缓存并发及缓存预热等问题,提供高可用解决方案,帮助你在大厂面试和实际工作中应对这些常见并发场景。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
    大厂面试高频:如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难题
    |
    2月前
    |
    存储 缓存 NoSQL
    【赵渝强老师】基于Redis的旁路缓存架构
    本文介绍了引入缓存后的系统架构,通过缓存可以提升访问性能、降低网络拥堵、减轻服务负载和增强可扩展性。文中提供了相关图片和视频讲解,并讨论了数据库读写分离、分库分表等方法来减轻数据库压力。同时,文章也指出了缓存可能带来的复杂度增加、成本提高和数据一致性问题。
    【赵渝强老师】基于Redis的旁路缓存架构
    |
    2月前
    |
    缓存 NoSQL Redis
    Redis 缓存使用的实践
    《Redis缓存最佳实践指南》涵盖缓存更新策略、缓存击穿防护、大key处理和性能优化。包括Cache Aside Pattern、Write Through、分布式锁、大key拆分和批量操作等技术,帮助你在项目中高效使用Redis缓存。
    329 22
    |
    2月前
    |
    缓存 NoSQL PHP
    Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出
    本文深入探讨了Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出。文章还介绍了Redis在页面缓存、数据缓存和会话缓存等应用场景中的使用,并强调了缓存数据一致性、过期时间设置、容量控制和安全问题的重要性。
    45 5