Redis数据失效监听

一、配置Redis开启

打开conf/redis.conf 文件,添加参数:notify-keyspace-events Ex

二、验证配置

  • 步骤一:进入redis客户端:redis-cli
  • 步骤二:执行 CONFIG GET notify-keyspace-events ,如果有返回值证明配置成功,如果没有执行步骤三
  • 步骤三:执行CONFIG SET notify-keyspace-events "Ex",再查看步骤二是否有值

三、两个类

package com.ciih.autopaddleGetway.config.redis;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.listener.RedisMessageListenerContainer;

import javax.annotation.Resource;

@Configuration
public class RedisConfig {

    @Resource
    private RedisConnectionFactory redisConnectionFactory;
    @Resource
    private RedisKeyExpirationListener redisExpiredListener;

    @Bean
    public RedisMessageListenerContainer redisMessageListenerContainer() {
        RedisMessageListenerContainer redisMessageListenerContainer = new RedisMessageListenerContainer();
        redisMessageListenerContainer.setConnectionFactory(redisConnectionFactory);
        //监听所有key的过期事件
        redisMessageListenerContainer.addMessageListener(redisExpiredListener, redisExpiredListener.getTopic());
        return redisMessageListenerContainer;
    }

}

 

package com.ciih.autopaddleGetway.config.redis;

import lombok.Data;
import org.springframework.data.redis.connection.Message;
import org.springframework.data.redis.connection.MessageListener;
import org.springframework.data.redis.listener.PatternTopic;
import org.springframework.stereotype.Component;

@Data
@Component
public class RedisKeyExpirationListener implements MessageListener {
    //监听的主题(只监听redis数据库1,如果要监听redis所有的库,把1替换为*)
    public final PatternTopic topic = new PatternTopic("__keyevent@1__:expired");

    /**
     * Redis失效事件 key
     *
     * @param message
     * @param pattern
     */
    @Override
    public void onMessage(Message message, byte[] pattern) {
        String expiraKey = message.toString();
        System.out.println(expiraKey + "触发了失效事件!!!!");
        System.out.println();
    }
}

在 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
发出的红包

打赏作者

文子阳

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值