Redis原理:发布与订阅

前言

在日常开发中,其实有较多的很成熟的消息队列中间件,如RocketMQ、RabbitMQ、Kafka等,其实Redis的发布/订阅机制,也是一种简单的消息队列机制。今天来分析下redis是如何实现的?

源码分析

Redis 通过publish\subscribe\unsubscribe来实现发布/订阅的功能。

发布

从 command.c 文件中,查找到publish的实现,publish 的命令为

publish channel message

在发布订阅时,会按完全匹配和模式匹配两种方式来查找客户端

完全匹配的客户端

模式匹配的客户端

那这些客户端的列表又是如何来的呢?这就是接下来要分析的订阅内容了。

订阅

通过subscribe 命令可以订阅channel中的消息。subscribe命令为

subscribe channel [channel ...]

以上是完全匹配的情况,那模式匹配是在哪里呢?具体看下 psubscribe的实现

总结

到这里,Redis的发布/订阅源码就分析完了,redis内部其实是用一个hash表来维护客户端与channel、channel与客户端的列表关系,具体可以查看前面的文章来了解结构。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值