博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
redis 超时失效key 的监听触发
阅读量:6194 次
发布时间:2019-06-21

本文共 3225 字,大约阅读时间需要 10 分钟。

1. 事件通过 Redis 的订阅与发布功能(pub/sub)来进行分发,故需要订

阅 __keyevent@0__:expired 通道

0表示db0 根据自己的dbindex选择合适的数字

 

2. 修改 redis.conf 文件 

修改 notify-keyspace-events Ex 

# K    键空间通知,以__keyspace@
__为前缀# E 键事件通知,以__keysevent@
__为前缀# g del , expipre , rename 等类型无关的通用命令的通知, ...# $ String命令# l List命令# s Set命令# h Hash命令# z 有序集合命令# x 过期事件(每次key过期时生成)# e 驱逐事件(当key在内存满了被清除时生成)# A g$lshzxe的别名,因此”AKE”意味着所有的事件

3. 重启redis , 即可测试失效事件的触发, 监听获取的值为 key

 

<java>

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, "__keyevent@0__:expired");          //other code      }  }

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

 

注意: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", "我是天才");          Thread.sleep(5000);          jedis.publish("redisChatTest", "我牛逼");          Thread.sleep(5000);          jedis.publish("redisChatTest", "哈哈");      }  }

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

转载地址:http://bluca.baihongyu.com/

你可能感兴趣的文章
Google AI子公司采用区块链技术来跟踪英国的健康数据
查看>>
力成科技股东会决议通过紫光投资案
查看>>
推荐10款免费的在线UI测试工具
查看>>
《嵌入式系统数字视频处理权威指南》—— 导读
查看>>
侵犯公民个人信息: “两高”首次出台司法解释 打击大数据征信乱象
查看>>
《Photoshop修色圣典(第5版)》—第1章1.13节你将是裁判
查看>>
《大数据算法》一2.4 数组有序的判定算法
查看>>
我的友情链接
查看>>
Xcode 7 缺少 *.dylib库的解决方法
查看>>
【MyBatis】缓存配置
查看>>
搭建nonde项目结构
查看>>
URL Management(网址管理)
查看>>
新手站长们看过来:白话ID
查看>>
Linux基础命令试题——第二周
查看>>
HighChart教程:如何使用Highcharts Cloud API(二)
查看>>
一句话,讲清楚java泛型的本质(非类型擦除)
查看>>
百度联合清华发布国内首个基于AI实践的产业智能化白皮书
查看>>
我的友情链接
查看>>
博文第一篇《明志》
查看>>
java Stack类 Vector类
查看>>