redis 超时失效key 的监听触发

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发布消息,第二步因为订阅了该频道,所以会收到该消息。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Java 中,你可以使用 Redisson 这个 Redis 客户端库来实现 Redis 键的失效监听Redisson 提供了 `RKeys` 类来操作 Redis 的键,并且可以通过 `addListener` 方法添加键的监听器。以下是一个示例代码: ```java import org.redisson.Redisson; import org.redisson.api.RKeys; import org.redisson.api.RedissonClient; import org.redisson.api.listener.KeyspaceExpiredListener; public class RedisKeyExpirationListenerExample { public static void main(String[] args) { // 创建 Redisson 客户端 RedissonClient redisson = Redisson.create(); // 获取键操作对象 RKeys keys = redisson.getKeys(); // 添加键失效监听keys.addListener(new KeyspaceExpiredListener() { @Override public void onExpired(String key) { System.out.println("Key expired: " + key); // 在这里处理键失效事件 } }); // 等待键失效事件发生 try { Thread.sleep(60000); // 60秒 } catch (InterruptedException e) { e.printStackTrace(); } // 关闭 Redisson 客户端 redisson.shutdown(); } } ``` 在上述示例中,我们使用 Redisson 创建了一个 Redis 客户端,并通过 `getKeys()` 方法获取了键操作对象 `RKeys`。然后,我们使用 `addListener` 方法添加了一个键失效监听器 `KeyspaceExpiredListener`,并在回调方法中处理键失效事件。 你可以根据需要在回调方法中编写自己的处理逻辑。在示例中,我们简单地打印出了失效的键。 最后,我们通过 `Thread.sleep` 方法让程序等待一段时间,以便触发失效事件。在实际应用中,你可以根据自己的需求来决定如何触发失效事件。 请确保你已经在项目中引入了 Redisson 的依赖。你可以通过 Maven 或 Gradle 在项目的构建文件中添加以下依赖: Maven: ```xml <dependency> <groupId>org.redisson</groupId> <artifactId>redisson</artifactId> <version>3.16.1</version> </dependency> ``` Gradle: ```groovy implementation 'org.redisson:redisson:3.16.1' ``` 请注意,上述示例中假设 Redis 运行在本地主机。你需要根据你自己的实际情况进行适配。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值