搜索热词
1.概念
名称及含义
channel频道:生产者和消费者直接操作的对象
publish生产者:向channel发送消息
subscribe消费者:订阅一个或多个channel
psubscribe消费者:匹配订阅一个或多个channel
punsubscribe退订:匹配退订,无参数则退订全部channel
unsubscribe退订:退订指定的channel,无参数则退订全部channel
pubsub列出当前活动channel(至少有一个订阅)
2.注意事项
1)生产者publish消息时打开一个连接,publish后连接可以立即关闭
2)channel只接收publish发送的消息,自身不存储消息,如果channel没有被订阅,则消息丢弃
3)订阅的消费者需要一直在线,阻塞获取消息,连接断开表示立即退订
3.redis可以实现发布订阅和消息队列的功能,两者的区别在于:
1)redis的订阅者可以是多个,且可以同时处理发布上来的消息,如果订阅者不在线(服务没有启动)消息将丢失,消息没有持久化。发布和订阅是一块执行的,缺少一个直接忽略这个消息
2)消息队列只能有一个客户端来处理,处理完之后消息就被标记或删除,即使服务端没有启动消息也不会丢失
3)两者的使用场景要根据业务数据的准确度,敏感性决定,比如日志就可以用redis发布订阅来实现,丢失一点也没有关系
4.直接使用PHP-redis扩展提供的方法实现发布订阅
1)消费者订阅Subs