Java实现Redis的消息订阅和发布
Posted nanaheidebk
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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发布消息,第二步因为订阅了该频道,所以会收到该消息。
以上是关于Java实现Redis的消息订阅和发布的主要内容,如果未能解决你的问题,请参考以下文章
基于redis(订阅发布)实现python和java进程间通信