一、命令行实现 Redis 的发布与订阅
1. 开启订阅者窗口与发布者窗口
开启几个 Redis 客户端,一个作为发布者,其余作为订阅者。
2. 订阅者订阅指定频道
订阅频道使用的命令:subscribe channel[channel…]
它的作用是:订阅一个或多个频道的信息
返回值:订阅的消息
3. 发布者向指定频道发布消息
消息发布使用命令:publish chanel message
它的作用:将message消息发送到channel频道。message是要发送的消息,channel是自定义的频道名称(例如cctv1,cctv5),唯一标识发布者。
返回值:数字。接收到消息订阅者的数量
4. 观察发布与订阅情况
二、Java 实现 Redis 的发布与订阅
1. 创建订阅者
实现订阅者只需 继承 JedisPubSub 类,并重写它的 onMessage()方法即可。
public class RedisSubScribe extends JedisPubSub {
/**
* 当订阅者接收到消息时回自动调用改方法
* @param channel 频道的名称
* @param message 发布的消息
*/
@Override
public void onMessage(String channel, String message) {
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
System.out.println("我是订阅者:订阅频道【" + channel + "】, 收到的消息是:【" + message + "】, 收到消息的时间为:【" + df.format(new Date()) + "】");
}
public static void main(String[] args) {
// 创建 Jedis
Jedis jedis = new Jedis("redis的ip地址", port);
// 创建 redisSubScribe 对象
RedisSubScribe redisSubScribe = new RedisSubScribe();
// Redis订阅
jedis.subscribe(redisSubScribe, "CCTV-1");
}
}
JedisPubSub类:Jedis中的JedisPubSub类是Jedis的一个抽象类,此类定义了publish
/subscribe的回调方法,通过继承JedisPubSub类,重写回调方法。实现java中Redis
的发布订阅。当Reids发生发布或订阅的相关事件时会调用这些回调方法。只在回调方法中
实现自己的业务逻辑。
onMessage():发布者发布消息时,会执行订阅者的回调方法onMessage(),接收发布的
消息。在此方法实现消息接收后的,自定义业务逻辑处理,比如访问数据库,更新库存等。
2. 创建订阅者
public class RedisPublish {
public static void main(String[] args) {
// 创建 Jedis
Jedis jedis = new Jedis("10.74.40.3", 6379);
jedis.publish("CCTV-1", "我们将于下月中旬上映《宝宝巴士》");
System.out.println("消息发布完毕..");
}
}
3. 运行查看结果
订阅者:
我是订阅者:订阅频道【CCTV-1】, 收到的消息是:【我们将于下月中旬上映《宝宝巴士》】, 收到消息的时间为:【2021-05-11 11:28:21】
发布者:
消息发布完毕..