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

阅 __keyevent@0__:expired 通道

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

2. 修改 redis.conf 文件 

修改 notify-keyspace-events Ex

# K    键空间通知,以__keyspace@<db>__为前缀
# E    键事件通知,以__keysevent@<db>__为前缀
# 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发布消息,第二步因为订阅了该频道,所以会收到该消息。

转载于:https://www.cnblogs.com/chen-lhx/p/6626371.html

redis 超时失效key 的监听触发相关推荐

  1. redis 超时key过期监听

    1.修改redis配置 过期事件通过Redis的订阅与发布功能(pub/sub)来进行分发. 而对超时的监听呢,并不需要自己发布,只有修改配置文件redis.conf中的:notify-keyspac ...

  2. Redis key过期监听

    RedisKey超时监听 Key过期会不会立即删除? 不会立即删除:由于Redis属于单线程,主服务不会第一时间删除Key.所有Key不会在第一时间被删除. 删除机制: (1)定期删除:Redis每一 ...

  3. php redis 实现缓存过期回调监听

    官方文档指出: Basically expired events are generated when the Redis server deletes the key and not when th ...

  4. waypoint+animate元素滚动监听触发插件实现页面动画效果

    最近在做一个官网类型滚动加载动画,使用到waypoint监听事件插件和animate动画样式,两者结合完美实现向下滚动加载动画,但是没有做向上滚动撤消动画,留待以后有空研究 首先来介绍下jquery. ...

  5. html鼠标滚轮监听,js鼠标滑轮滚动监听触发事件

    判断鼠标滚动方向执行不同的事件代码,兼容IE.Firefox.chrome浏览器.javascript代码如下: var scrollFunc = function (e) { var direct ...

  6. Redis自动过期机制之key的过期监听(7)

    Redis中的自动过期机制 前言 1.使用Redis Key自动过期机制 2.Springboot整合key过期监听 2.1. 创建表 order_number 2.2核心代码 2.2.1 核心代码 ...

  7. Redis key过期事件监听实现 - 30分钟自动取消未支付订单

    目录 一.前言 二.实现方案分析 三.Redis key过期事件方案实现步骤 3.1 Redis 安装步骤详见 3.2 修改 Redis 配置 3.3 在获取支付链接视图中设置key过期事件 3.4 ...

  8. redis开启过期监听

    java项目中,场景:订单没有付款到期取消订单,使用的是redis过期监听来做的,做个笔记!首先使用该功能需要下载2.8.0及以上的版本,这一部分详细内容可以访问redis官网:http://redi ...

  9. Springboot redis多数据源过期监听案例

    在上一篇Springboot redis多数据源案例中,我们实现了springboot下多数据源的案例. 本篇博客在此基础上,实现多数据源过期监听事件: 监听器配置类: package com.xin ...

最新文章

  1. ICLR 2020 | ReClor: 一个需要逻辑推理的阅读理解数据集
  2. VTK:Rendering之WalkCow
  3. 数据结构--图(Graph)详解(四)
  4. Linux基础命令---findfs
  5. Spark Windows
  6. Qt实现全屏下玫瑰花(含详细注释)
  7. java语法优化小结
  8. tornado+websocket+mongodb实现在线视屏文字聊天
  9. lvs+keepalived实现负载均衡和高可用
  10. C#高级编程之C#基础知识
  11. Matlab简单图像运算实例
  12. 多彩M618鼠标 拆解相关
  13. 不要STUPID,坚持GRASP和SOLID
  14. FPGA 串口通信(补)——通用模块
  15. UE4材质(二):PBR材质
  16. YDOOK:Pytorch教程:转置矩阵 转置张量 T
  17. 无人驾驶车辆纵向速度PID控制
  18. java,民族类型枚举
  19. List------数据结构
  20. java对接阿里云短信平台

热门文章

  1. vue组件化通信之父向子传值
  2. 循环队列及C语言实现三
  3. Nuc972使用NandFlash时,uboot所需要的改动
  4. 前端学习(3008):vue+element今日头条管理--登录中的loding
  5. 工作380-js判断是否为空
  6. 前端学习(2799):实现资讯的结构和列表
  7. 工作44:阅读代码1 dictionary
  8. 前端学习(2382):js编码规范说明
  9. 前端学习(2048)vue之电商管理系统电商系统之实现首页内容自定制
  10. 前端学习(1845)vue之电商管理系统项目实战的学习目标