Java和命令行实现Redis的发布订阅

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

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

开启几个 Redis 客户端,一个作为发布者,其余作为订阅者。
Java和命令行实现Redis的发布订阅_第1张图片

2. 订阅者订阅指定频道

订阅频道使用的命令subscribe channel[channel…]
它的作用是:订阅一个或多个频道的信息
返回值:订阅的消息
Java和命令行实现Redis的发布订阅_第2张图片

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

消息发布使用命令publish chanel message
它的作用:将message消息发送到channel频道。message是要发送的消息,channel是自定义的频道名称(例如cctv1,cctv5),唯一标识发布者。
返回值:数字。接收到消息订阅者的数量
Java和命令行实现Redis的发布订阅_第3张图片

4. 观察发布与订阅情况

Java和命令行实现Redis的发布订阅_第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

发布者:


消息发布完毕..


技 术 无 他, 唯 有 熟 尔。
知 其 然, 也 知 其 所 以 然。
踏 实 一 些, 不 要 着 急, 你 想 要 的 岁 月 都 会 给 你。


你可能感兴趣的:(Java,redis,redis,java,jedis,发布订阅)