其实在很多的MQ产品中都存在这样的一个模式,我们常听到的一个例子就是邮件订阅的场景,什么意思呢,也就是说100个人订阅了你的博客,如果博主发表了文章,那么100个人就会同时收到通知邮件,除了这个场景还能找到其他场景么,当然有啦,你想想,如果你要在内存里面做一个读写分离的程序,为了维持数据的完整性,你是不是需要保证在写入的时候,也要分发到各个读内存的程序中呢?所以说场景还是很多的,在于你的挖掘~~~ 下面还是从基本命令入手:

一:命令简介
从redis手册上面可以看到,其实“发布、订阅”模式才区区6个命令,下面听我一一解说下哈~~~
1. subscribe
SUBSCRIBE channel [channel ...]
订阅给定的一个或多个频道的信息。
从上面的官方解释上来看,它的玩法有一点像现实生活中我们听收音机一个道理,要想听收音机,我们要做什么?肯定就是调频啦,只有在正确的频道上面,我们才能听得到好听的节目,所以说subscribe首先要订阅一个频道(channel),下面我举个例子,开两个client,分别订阅着msg 这个频道,比如下面这样:
2.publish
到现在为止,这两个subscibe都在监视着msg这个频道,接下来,如果msg频道有消息传出,必定会被subscribe接收到,先我们还是看看redis手册上怎么用这个命令。
PUBLISH channel message
将信息 message 发送到指定的频道 channel 。
看到上面命令的用法,我也就放心了。
看到么有,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的发布订阅模式,使用RedisServer下面的 pubsub_channels字典 和 pubsub_patterns数组存放的,所有的操作代码都
在pubsub.c文件下,如下图:
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就知道结果了。
4. publishCommand
先前也说了,publish的原理很简单,就是找到字典中的channel这个key,获取到clients之后,遍历client的来发送信息。
同样的道理,pubsub_patterns也是差不多的实现,只要大家简单看一下pubsub.c这个源代码文件,差不多都会懂得
# redis发布订阅
# redis
# 发布订阅命令
# redis发布订阅Java代码实现过程解析
# redis发布和订阅_动力节点Java学院整理
# Redis 订阅发布_Jedis实现方法
# Redis发布订阅和实现.NET客户端详解
# 浅谈我是如何用redis做实时订阅推送的
# 对吧
# 好了
# 你是
# 多个
# 遍历
# 很简单
# 可以看到
# 我就
# 就会
# 如果你
# 是在
# 就在
# 你可以
# 都在
# 你就
# 也就
# 也要
# 说了
# 还能
# 我一
相关文章:
小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?
建站之星3.0如何解决常见操作问题?
宝塔建站助手安装配置与建站模板使用全流程解析
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
建站之星安装后界面空白如何解决?
齐河建站公司:营销型网站建设与SEO优化双核驱动策略
成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?
行程制作网站有哪些,第三方机票电子行程单怎么开?
建站上市公司网站建设方案与SEO优化服务定制指南
建站之星安装失败:服务器环境不兼容?
如何基于PHP生成高效IDC网络公司建站源码?
如何在阿里云ECS服务器部署织梦CMS网站?
广州网站建站公司选择指南:建站流程与SEO优化关键词解析
枣阳网站制作,阳新火车站打的到仙岛湖多少钱?
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
建站之星如何助力企业快速打造五合一网站?
长沙做网站要多少钱,长沙国安网络怎么样?
如何通过虚拟主机快速搭建个人网站?
如何获取开源自助建站系统免费下载链接?
如何高效利用200m空间完成建站?
如何零基础开发自助建站系统?完整教程解析
定制建站如何定义?其核心优势是什么?
宁波自助建站系统如何快速打造专业企业网站?
西安大型网站制作公司,西安招聘网站最好的是哪个?
免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?
如何配置支付宝与微信支付功能?
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
,怎么在广州志愿者网站注册?
相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?
微课制作网站有哪些,微课网怎么进?
如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?
如何通过免费商城建站系统源码自定义网站主题与功能?
网站制作公司排行榜,抖音怎样做个人官方网站
网站制作的步骤包括,正确网址格式怎么写?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
一键网站制作软件,义乌购一件代发流程?
建站之星免费版是否永久可用?
如何快速搭建FTP站点实现文件共享?
制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
北京建设网站制作公司,北京古代建筑博物馆预约官网?
魔方云NAT建站如何实现端口转发?
如何快速上传建站程序避免常见错误?
微网站制作教程,我微信里的网站怎么才能复制到浏览器里?
c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】
,在苏州找工作,上哪个网站比较好?
利用JavaScript实现拖拽改变元素大小
昆明高端网站制作公司,昆明公租房申请网上登录入口?
*请认真填写需求信息,我们会在24小时内与您取得联系。