Redis 订阅与发布

Redis是一个key-value的存储系统,提供的key-value类似与Memcached而数据结构又多于memcached,而且性能优异.广泛用于缓存,临时存储等,不仅如此redis pubsub还可以实现发布–订阅功能,实时推送给订阅端。

1.实现发布功能

Redis技术学习 https://www.itkc8.com

[java] view plain copy  print?在CODE上查看代码片派生到我的代码片

  1. package cn.slimsmart.redis.spring.data.redis.pubsub;  
  2.   
  3. import redis.clients.jedis.Jedis;  
  4. import redis.clients.jedis.JedisPool;  
  5. import redis.clients.jedis.JedisPoolConfig;  
  6.   
  7. public class JedisPubSubTest {  
  8.     static JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();  
  9.     static {  
  10.         jedisPoolConfig.setMaxTotal(10);  
  11.         jedisPoolConfig.setMaxIdle(2);  
  12.     }  
  13.     static JedisPool pool = new JedisPool(jedisPoolConfig, "127.0.0.1"63795000);  
  14.   
  15.     public static void main(String[] args) {  
  16.         Jedis jedis = pool.getResource();  
  17.         try {  
  18.             jedis.publish("test_channel""hello word!");  
  19.         } finally {  
  20.             pool.returnResource(jedis);  
  21.         }  
  22.         pool.destroy();  
  23.     }  
  24. }  

 

2.实现发布订阅功能
继续JedisPubSub类实现对订阅到消息后的处理。

 

[java] view plain copy  print?在CODE上查看代码片派生到我的代码片

  1. package cn.slimsmart.redis.spring.data.redis.pubsub;  
  2.   
  3. import redis.clients.jedis.JedisPubSub;  
  4.   
  5. public class JedisPubSubListener extends JedisPubSub {  
  6.     @Override  
  7.     public void onMessage(String channel, String message) {  
  8.         // 取得订阅的消息后的处理  
  9.         System.out.println(channel + "    " + message);  
  10.     }  
  11.   
  12.     @Override  
  13.     public void onPMessage(String pattern, String channel, String message) {  
  14.         // 取得按表达式的方式订阅的消息后的处理  
  15.     }  
  16.   
  17.     @Override  
  18.     public void onPSubscribe(String pattern, int subscribedChannels) {  
  19.         // 初始化按表达式的方式订阅时候的处理  
  20.     }  
  21.   
  22.     @Override  
  23.     public void onPUnsubscribe(String pattern, int subscribedChannels) {  
  24.         // 取消按表达式的方式订阅时候的处理  
  25.     }  
  26.   
  27.     @Override  
  28.     public void onSubscribe(String channel, int subscribedChannels) {  
  29.         // 初始化订阅时候的处理  
  30.     }  
  31.   
  32.     @Override  
  33.     public void onUnsubscribe(String channel, int subscribedChannels) {  
  34.         // 取消订阅时候的处理  
  35.     }  
  36. }  

 

3.测试订阅功能

 

[java] view plain copy  print?在CODE上查看代码片派生到我的代码片

  1. package cn.slimsmart.redis.spring.data.redis.pubsub;  
  2.   
  3. import redis.clients.jedis.Jedis;  
  4. import redis.clients.jedis.JedisPool;  
  5. import redis.clients.jedis.JedisPoolConfig;  
  6.   
  7. public class JedisTest {  
  8.     static JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();  
  9.     static {  
  10.         jedisPoolConfig.setMaxTotal(10);  
  11.         jedisPoolConfig.setMaxIdle(2);  
  12.     }  
  13.     static JedisPool pool = new JedisPool(jedisPoolConfig, "127.0.0.1"63795000);  
  14.     public static void main(String[] args) {  
  15.         Jedis jedis = pool.getResource();  
  16.         try {  
  17.             JedisPubSubListener pubsub = new JedisPubSubListener();  
  18.             //订阅  
  19.             jedis.subscribe(pubsub, "hq_xq_pubsub");  
  20.         } finally {  
  21.             pool.returnResource(jedis);  
  22.         }  
  23.         pool.destroy();  
  24.     }  
  25. }  

Redis技术学习 https://www.itkc8.com

测试的时候先启动JedisTest 类,然后再启动JedisPubSubTest类。主要运行原理就是socket。

关于spring-data-redis实现发布订阅,请参考文章:

Spring Data Redis实现一个订阅/发布系统

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值