南县中国建设银行网站,it网站开发公司,商业综合体,重庆网站设计总部一、Redis的发布订阅
Redis的发布与订阅功能由PUBLISH、SUBSCRIBE、PSUBSCRIBE等命令组成。通过执行SUBSCRIBE命令#xff0c;客户端可以订阅一个或多个频道#xff0c;从而成为这些频道的订阅者#xff08;subscriber#xff09;#xff1a;每当有其他客户端向被订阅的频…一、Redis的发布订阅
Redis的发布与订阅功能由PUBLISH、SUBSCRIBE、PSUBSCRIBE等命令组成。通过执行SUBSCRIBE命令客户端可以订阅一个或多个频道从而成为这些频道的订阅者subscriber每当有其他客户端向被订阅的频道发送消息message时频道的所有订阅者都会收到这条消息。 消息订阅有两种模式一种是频道订阅另一种是模式订阅。 频道订阅
SUBSCRIBE news.it模式订阅
PSUBSCRIBE news.*二、发布订阅实现原理
RedisServer结构体里有一个为pubsub_channels字典另一个为pubsub_patterns链表。第一个字典key保存着频道value是一个链表保存订阅该频道的客户端信息链表则保存着订阅频道模式的客户端信息
struct redisServer {// ...//保存所有频道的订阅关系dict *pubsub_channels;list *pubsub_patterns;// ...
};消息发送时只需要遍历字典和链表将消息发送给订阅相关频道的客户端即可