redis监听key过期

查看redis版本:

redis-server -v 
redis-server --version

在window下,下载redis:https://github.com/MicrosoftArchive/redis/releases
linux下可以直接在官网下载即可:https://redis.io/

要使redis可以监听到key过期,需添加配置,
实现原理:在Redis2.8之后的版本中,当我们将<key, value>对使用Redis缓存起来并设置缓存失效时间的时候,会触发Redis的键事件通知,客户端订阅这个通知事件,服务端会将对应的通知事件发送给每个订阅的客户端,然后客户端根据收到的通知,做相应的后续处理(例如:键过期时间通知对应的topic为:“keyevent@0:expired”)。
因为开启键空间通知功能需要消耗一些 CPU ,所以在默认配置下,该功能处于关闭状态。
我的配置是这样的:

notify-keyspace-events Ex

在这里插入图片描述

java监听过期key实现发布订阅

https://yidajava.blog.csdn.net/article/details/84202550

在Java中,使用Redis时可以通过设置键(key)的过期时间来自动删除不再使用的数据,以节省内存。为了监听key过期事件,可以使用Redis的发布/订阅(Pub/Sub)机制。 要实现这个功能,需要两个步骤: 1. 开启一个单独的线程或使用Spring框架的消息监听器,订阅名为`__keyevent@<db>__:`的频道,其中`<db>`是Redis数据库的编号。通常情况下,监听的是`__keyevent@0__:expired`,因为它是在默认数据库上的过期事件。 2. 当有key过期时,Redis服务器会向订阅了`__keyevent@<db>__:`频道的客户端发布过期事件消息。客户端需要编写相应的代码来接收并处理这些消息。 以下是一个简单的使用Jedis客户端库进行监听key过期事件的示例代码: ```java import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisPubSub; public class RedisExpiredListener extends JedisPubSub { @Override public void onPSubscribe(String pattern, int subscribedChannels) { System.out.println("已订阅过期事件:" + pattern); } @Override public void onPMessage(String pattern, String channel, String message) { if ("__keyevent@0__:expired".equals(channel)) { System.out.println("键:" + message + " 已过期"); } } public void startListening() { Jedis jedis = new Jedis("localhost", 6379); jedis.psubscribe(this, "__keyevent@0__:expired"); } public static void main(String[] args) { new RedisExpiredListener().startListening(); } } ``` 在这个示例中,我们创建了一个`RedisExpiredListener`类,它继承了`JedisPubSub`类,并重写了`onPSubscribe`和`onPMessage`方法来处理订阅事件和接收到的过期消息。`startListening`方法用于开始监听过期事件。 需要注意的是,监听key过期事件可能会对性能有一定影响,特别是在Redis服务器有大量key过期事件发生的情况下。因此,在生产环境中使用时需要谨慎评估性能影响。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值