redis 发布订阅模式及应用场景

redis 发布订阅模式及应用场景一 命令简介 从 redis 手册上面可以看到 其实 发布 订阅 模式才区区 6 个命令 下面听我一一解说下哈 nbsp 1 subscribeSUB channel 订阅给定的一个或多个频道的信息 nbsp nbsp nbsp 从上面的官方解释上来看 它的玩法有一点像现实生活中我们听收音机一个道理 要想听收音机 我们要做什么 肯定就是调频啦 只有在正确的频道上面 我们才能听得到好听

一:命令简介

  redis 发布订阅模式及应用场景

从redis手册上面可以看到,其实“发布、订阅”模式才区区6个命令,下面听我一一解说下哈~~~

 

1. subscribe

SUBSCRIBE channel [channel ...] 订阅给定的一个或多个频道的信息。

     从上面的官方解释上来看,它的玩法有一点像现实生活中我们听收音机一个道理,要想听收音机,我们要做什么?肯定就是调频啦,只有在正

确的频道上面,我们才能听得到好听的节目,所以说subscribe首先要订阅一个频道(channel),下面我举个例子,开两个client,分别订阅着

msg 这个频道,比如下面这样:

redis 发布订阅模式及应用场景

 

2.publish

   到现在为止,这两个subscibe都在监视着msg这个频道,接下来,如果msg频道有消息传出,必定会被subscribe接收到,先我们还是看看

redis手册上怎么用这个命令。

PUBLISH channel message 将信息 message 发送到指定的频道 channel 。

看到上面命令的用法,我也就放心了。

redis 发布订阅模式及应用场景

看到么有,publish在msg这个频道上面发送消息后,被subscribe监视到了,然后就被分别打印输出了,好了,到现在为止,最基本的发布

订阅模式就是这样,是不是很简单哈。。。其实呢??? 也就是这么简单呐,但是呢,有时候我们还有这样一个需求,就是我能不能模糊匹

配key呢???举了例子,就是要求订阅china为前缀的所有频道,如果这样也可以做到的话,那确实是很牛逼啦。。。我要是回答的话,当

然啦,强大的redis自然会做到这一点,它提供了的命令就是:Psubscribe。

 

3. Psubscribe

PSUBSCRIBE pattern [pattern ...] 订阅一个或多个符合给定模式的频道。 每个模式以 * 作为匹配符,比如 it* 匹配所有以 it 开头的频道( it.news 、 it.blog 、 it.tweets 等等), news.* 匹配所有以 news. 开头的频道( news.it 、 news.global.today 等等),诸如此类。

看到上面的解释,你心里可能就在想,这不就是正则匹配么。。。而且前缀“P”就是Pattern的意思,对吧,接下来我就订阅一下所有china为

前缀的channel。

redis 发布订阅模式及应用场景

好了,最常用的也就是这三个命令,接下来我们简单分析一下代码。

 

二: 源码简单分析

  其实redis的发布订阅模式,使用RedisServer下面的 pubsub_channels字典 和 pubsub_patterns数组存放的,所有的操作代码都

在pubsub.c文件下,如下图:

redis 发布订阅模式及应用场景

1.   pubsub_channels 

      可以看到,它是一个字典结构,通过注释你应该明白,它的key为channel,value为list。

 

2.   pubsub_patterns

      同样从注释中,你可以看到,其实它就是存放模式匹配的subscribe的clients列表,对吧,用一个list数组实现。

 

3.   subcribeCommand

      通过下面的代码,你是不是在脑子里面很有轮廓了???其实这个pubsub_channels果然就是key=channel,value=list的存放模式,

这个list就是所谓的clients列表,这样的话,你就知道了哪些key挂了哪些clients,对吧,如果再publish的话,只需要遍历一下这个list就知

道结果了。

redis 发布订阅模式及应用场景

 

4.  publishCommand

  先前也说了,publish的原理很简单,就是找到字典中的channel这个key,获取到clients之后,遍历client的来发送信息。

   redis 发布订阅模式及应用场景

同样的道理,pubsub_patterns也是差不多的实现,只要大家简单看一下pubsub.c这个源代码文件,差不多都会懂得,没啥好说的,

希望这篇对你有用~

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/231247.html原文链接:https://javaforall.net

(0)
上一篇 2026年1月19日 下午3:01
下一篇 2026年1月19日 下午3:22


相关推荐

  • linux卸载mysql(完全卸载)[通俗易懂]

    linux卸载mysql(完全卸载)[通俗易懂]//rpm包安装方式卸载查包名:rpm-qa|grep-imysql删除命令:rpm-e–nodeps包名//yum安装方式下载1.查看已安装的mysql命令:rpm-qa|grep-imysql2.卸载mysql命令:yumremovemysql-community-server-5.6.36-2.el7.x86_64查看mysql的其它依赖:rpm…

    2022年6月29日
    29
  • 数学四大思想八大方法_数学八种思维方法

    数学八种思维方法2020-03-1916:00:03文/董玉莹数学八种思维方法:代数思想、数形结合、转化思想、对应思想方法、假设思想方法、比较思想方法、符号化思想方法、极限思想方法。代数思想这是基本的数学思想之一,小学阶段的设未知数x,初中阶段的一系列的用字母代表数,这都是代数思想,也是代数这门学科最基础的根!数形结合是数学中最重要的,也是最基本的思想方法之一,是解决许多数学问题的有效思想。“…

    2022年4月8日
    196
  • java 缓冲区溢出_缓冲区溢出详解

    java 缓冲区溢出_缓冲区溢出详解1 缓冲区溢出原理缓冲区是一块连续的计算机内存区域 可保存相同数据类型的多个实例 缓冲区可以是堆栈 自动变量 堆 动态内存 和静态数据区 全局或静态 在 C C 语言中 通常使用字符数组和 malloc new 之类内存分配函数实现缓冲区 溢出指数据被添加到分配给该缓冲区的内存块之外 缓冲区溢出是最常见的程序缺陷 栈帧结构的引入为高级语言中实现函数或过程调用提供直接的硬件支持 但由于将函数返回地址

    2026年3月18日
    1
  • 手眼标定过程记录

    手眼标定过程记录手眼标定过程记录============================================================================================以下四个变量是最重要的数据rvecs_rb2gripper,tvecs_rb2gripperrvecs_cam,tvecs_cam1.首先排查机械臂末端到底座的旋转平移

    2022年5月27日
    39
  • 腾讯一口气发布五款龙虾

    腾讯一口气发布五款龙虾

    2026年3月12日
    2
  • 远程连接mysql8,报错10061 解决办法「建议收藏」

    远程连接mysql8,报错10061 解决办法「建议收藏」mysql8.0的1,检查服务器mysql服务是否启动100612,mysql必须设置密码,不然报错10061usemysql;updateusersetauthentication_string=””whereuser=“root”;flushprivileges;ALTERUSER‘root’@’%’IDENTIFIEDWITHmysql_native_passwordBY‘密码’;3,selectHost,Userfromuser;查看roo

    2022年10月13日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号