• Java实现Redis的消息订阅和发布


    1.  首先需要一个消息监听器类

    package com.sogou.baike.testimport.testSubscribe;
     
    import redis.clients.jedis.JedisPubSub;
     
    /**
     * Created by denglinjie on 2016/6/29.
     */
    public class RedisMsgPubSubListener extends JedisPubSub {
        @Override
        public void unsubscribe() {
            super.unsubscribe();
        }
     
        @Override
        public void unsubscribe(String... channels) {
            super.unsubscribe(channels);
        }
     
        @Override
        public void subscribe(String... channels) {
            super.subscribe(channels);
        }
     
        @Override
        public void psubscribe(String... patterns) {
            super.psubscribe(patterns);
        }
     
        @Override
        public void punsubscribe() {
            super.punsubscribe();
        }
     
        @Override
        public void punsubscribe(String... patterns) {
            super.punsubscribe(patterns);
        }
     
        @Override
        public void onMessage(String channel, String message) {
            System.out.println("channel:" + channel + "receives message :" + message);
            this.unsubscribe();
        }
     
        @Override
        public void onPMessage(String pattern, String channel, String message) {
     
        }
     
        @Override
        public void onSubscribe(String channel, int subscribedChannels) {
            System.out.println("channel:" + channel + "is been subscribed:" + subscribedChannels);
        }
     
        @Override
        public void onPUnsubscribe(String pattern, int subscribedChannels) {
     
        }
     
        @Override
        public void onPSubscribe(String pattern, int subscribedChannels) {
     
        }
     
        @Override
        public void onUnsubscribe(String channel, int subscribedChannels) {
            System.out.println("channel:" + channel + "is been unsubscribed:" + subscribedChannels);
        }
    }

    该类需要继承JedisPubSub ,并实现其抽象方法,通过方法的名称很清楚的看出来,这个监听器是用来订阅一个频道,在订阅该频道,取消订阅,收到消息等状态会对应调用相关的方法

    2.  订阅测试类

    public class TestSubscribe {
        @Test
        public void testSubscribe() throws Exception{
            Jedis jedis = new Jedis("localhost");
            RedisMsgPubSubListener listener = new RedisMsgPubSubListener();
            jedis.subscribe(listener, "redisChatTest");
            //other code
        }
    }

    该类实现对频道redisChatTest的订阅监听,频道的订阅,取消订阅,收到消息都会调用listener对象的对应方法

    如果对Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化、分布式架构。感兴趣可以747981058,群内会有不定期的发放免费的资料链接,这些资料都是从各个技术网站搜集、整理出来的,如果你有好的学习资料可以私聊发我,我会注明出处之后分享给大家。

    注意:subscribe是一个阻塞的方法,在取消订阅该频道前,会一直阻塞在这,只有当取消了订阅才会执行下面的other code,参考上面代码,我在onMessage里面收到消息后,调用了this.unsubscribe(); 来取消订阅,这样才会执行后面的other code

    3.  发布消息测试类

    Public class TestPublish {
        @Test
        public void testPublish() throws Exception{
            Jedis jedis = new Jedis("localhost");
            jedis.publish("redisChatTest", "Java架构技术交流");
            Thread.sleep(5000);
            jedis.publish("redisChatTest", "加入");
            Thread.sleep(5000);
            jedis.publish("redisChatTest", "747981058");
        }
    }

    这个类向频道redisChatTest发布消息,第二步因为订阅了该频道,所以会收到该消息。

  • 相关阅读:
    jquery 全选反选 .prop('checked',!$(this).is(':checked'));
    C#字典 Dictionary<Tkey,Tvalue> 之线程安全问题 ConcurrentDictionary<Tkey,Tvalue> 多线程字典
    javascript 获取iframe里页面中元素值的方法 关于contentWindow和contentDocumen
    WPF 之 UI 异步交互
    layui 解决从子页面传值回父页面方法
    layui 解决文本框只输入数字方法
    layui 合计出现多位小数的解决方法
    Jquery.Cookie 使用
    Git 上传代码步骤
    2分钟教你如何彻底删除Win10中 Windows.old 文件夹
  • 原文地址:https://www.cnblogs.com/nanaheidebk/p/11027586.html
Copyright © 2020-2023  润新知