redis 超时失效key 的监听触发详解编程语言
2023-06-13 09:20:46 时间
1. 事件通过 Redis 的订阅与发布功能(pub/sub)来进行分发,故需要订
阅 [email protected]__: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, "[email protected]__: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发布消息,第二步因为订阅了该频道,所以会收到该消息。
原创文章,作者:Maggie-Hunter,如若转载,请注明出处:https://blog.ytso.com/16202.html
cgojava相关文章
- 【Redis 系列】redis 学习十一,redis 的哨兵模式详解和实战
- Redis详解(二)—— redis的配置文件介绍大数据
- Python操作Redis、Memcache、RabbitMQ、SQLAlchemy详解编程语言
- [Redis] redis在centos下安装测试详解编程语言
- 用redis的scan命令代替keys命令,以及在spring-data-redis中遇到的问题详解编程语言
- Spring Boot(三):Spring Boot中Redis的使用详解编程语言
- Redis在win7上的安装与可视化应用详解编程语言
- Redis 参数优化:极致性能指南(redis参数详解)
- Redis字符集详解:了解Redis支持哪些字符集和对应使用场景(redis字符集)
- 深入浅出:Redis 命令解析(redis命令详解)
- Redis条件查询详解(redis的条件查询)
- 保护本地Redis安全设置密码(给本地redis设置密码)
- 数据库中 高效导入Redis缓存(数据库导入redis)
- 五游联盟联合Redis开创新纪元(五游联盟redis)
- 使用Vue和Redis创建完美的后台应用(vue redis后台)
- Redis面试攻略视频教程帮你打面试的基础(redis 面试视频教程)
- Redis中的会话存储把握住未来的秘诀(会话存redis)
- Redis集群突发危机主节点关闭(redis集群关闭主节点)
- Redis集群实现高可用的优势分析(redis集群vs 单机)
- Redis队列深入浅出以解锁动态管理能力(redis 队列详解)
- Redis连接参数详解(redis连接参数说明)
- Redis强大的过期策略如何有效应用(redis过期策略怎么用)
- Redis哨兵机制深入解析(redis详解5哨兵)
- 从零开始体验Redis的试用场景(redis 试用场景)
- Redis技术快速入门视频详解(redis视频介绍)
- Redis脑图深入剖析,一图读懂机制(redis脑图详解)
- 深入浅出Redis群集详解(redis群集详解)
- 使用Redis时如何解决连接缓慢问题(redis连接缓慢)