一、命令行实现 Redis 的发布与订阅

1. 开启订阅者窗口与发布者窗口

开启几个 Redis 客户端,一个作为发布者,其余作为订阅者。

emq java订阅编程 java实现发布订阅_emq java订阅编程

2. 订阅者订阅指定频道

订阅频道使用的命令subscribe channel[channel…]它的作用是:订阅一个或多个频道的信息

返回值:订阅的消息

emq java订阅编程 java实现发布订阅_redis_02

3. 发布者向指定频道发布消息

消息发布使用命令publish chanel message它的作用:将message消息发送到channel频道。message是要发送的消息,channel是自定义的频道名称(例如cctv1,cctv5),唯一标识发布者。

返回值:数字。接收到消息订阅者的数量

emq java订阅编程 java实现发布订阅_java_03

4. 观察发布与订阅情况

emq java订阅编程 java实现发布订阅_java_04

二、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】

发布者:

消息发布完毕..