前言
在日常开发中,其实有较多的很成熟的消息队列中间件,如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与客户端的列表关系,具体可以查看前面的文章来了解结构。