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

来源:互联网 发布:java 引用js文件 编辑:程序博客网 时间:2024/05/22 15:40

http://blog.csdn.net/u011734144/article/details/51782085


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

[html] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. package com.sogou.baike.testimport.testSubscribe;  
  2.   
  3. import redis.clients.jedis.JedisPubSub;  
  4.   
  5. /**  
  6.  * Created by denglinjie on 2016/6/29.  
  7.  */  
  8. public class RedisMsgPubSubListener extends JedisPubSub {  
  9.     @Override  
  10.     public void unsubscribe() {  
  11.         super.unsubscribe();  
  12.     }  
  13.   
  14.     @Override  
  15.     public void unsubscribe(String... channels) {  
  16.         super.unsubscribe(channels);  
  17.     }  
  18.   
  19.     @Override  
  20.     public void subscribe(String... channels) {  
  21.         super.subscribe(channels);  
  22.     }  
  23.   
  24.     @Override  
  25.     public void psubscribe(String... patterns) {  
  26.         super.psubscribe(patterns);  
  27.     }  
  28.   
  29.     @Override  
  30.     public void punsubscribe() {  
  31.         super.punsubscribe();  
  32.     }  
  33.   
  34.     @Override  
  35.     public void punsubscribe(String... patterns) {  
  36.         super.punsubscribe(patterns);  
  37.     }  
  38.   
  39.     @Override  
  40.     public void onMessage(String channel, String message) {  
  41.         System.out.println("channel:" + channel + "receives message :" + message);  
  42.         this.unsubscribe();  
  43.     }  
  44.   
  45.     @Override  
  46.     public void onPMessage(String pattern, String channel, String message) {  
  47.   
  48.     }  
  49.   
  50.     @Override  
  51.     public void onSubscribe(String channel, int subscribedChannels) {  
  52.         System.out.println("channel:" + channel + "is been subscribed:" + subscribedChannels);  
  53.     }  
  54.   
  55.     @Override  
  56.     public void onPUnsubscribe(String pattern, int subscribedChannels) {  
  57.   
  58.     }  
  59.   
  60.     @Override  
  61.     public void onPSubscribe(String pattern, int subscribedChannels) {  
  62.   
  63.     }  
  64.   
  65.     @Override  
  66.     public void onUnsubscribe(String channel, int subscribedChannels) {  
  67.         System.out.println("channel:" + channel + "is been unsubscribed:" + subscribedChannels);  
  68.     }  
  69. }  
该类需要继承JedisPubSub ,并实现其抽象方法,通过方法的名称很清楚的看出来,这个监听器是用来订阅一个频道,在订阅该频道,取消订阅,收到消息等状态会对应调用相关的方法


2.  订阅测试类

[html] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. public class TestSubscribe {  
  2.     @Test  
  3.     public void testSubscribe() throws Exception{  
  4.         Jedis jedis = new Jedis("localhost");  
  5.         RedisMsgPubSubListener listener = new RedisMsgPubSubListener();  
  6.         jedis.subscribe(listener, "redisChatTest");  
  7.         //other code  
  8.     }  
  9. }  
该类实现对频道redisChatTest的订阅监听,频道的订阅,取消订阅,收到消息都会调用listener对象的对应方法

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


3.  发布消息测试类

[html] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. Public class TestPublish {  
  2.     @Test  
  3.     public void testPublish() throws Exception{  
  4.         Jedis jedis = new Jedis("localhost");  
  5.         jedis.publish("redisChatTest", "我是天才");  
  6.         Thread.sleep(5000);  
  7.         jedis.publish("redisChatTest", "我牛逼");  
  8.         Thread.sleep(5000);  
  9.         jedis.publish("redisChatTest", "哈哈");  
  10.     }  
  11. }  
这个类向频道redisChatTest发布消息,第二步因为订阅了该频道,所以会收到该消息。
0 0
原创粉丝点击