目录
以前钻研Java多线程编程时有接触到一种并发编程方式叫反应式编程,当时这方面学习不深入,简单来说反应式编程就是处理异步流中的数据,因为以流的形式处理数据,所以执行效率很高。反应式编程其中一个重要特点是消息驱动,即对输入有反应,典型的消息处理模式是“发布-订阅”模式,记得Java中用到的组件是Publisher和Subscriber,分别代表发布者和订阅者。回到Redis,在Redis中也有这一经典消息传递模式,这篇日志就来总结下Redis发布订阅模式和Lua脚本相关。
发布-订阅模式
发布-订阅模式是经典的消息传递模式,发布者发布消息,订阅者接收消息,除此之外还有一个组成部分:Channel,在Redis里,Channel频道作为Redis服务器端,发布者和订阅者作为Redis客户端,Redis订阅者客户端可以订阅多个频道,发布者如果想要发布消息,会将消息发送到PubSub Channel中,PubSub频道会将消息发送给每一个订阅了该频道的订阅者。
示例
来具体看个例子: