一、服务器redis开启过期通知:
redis默认key过期通知是关闭的,因为它实际上是监听的(keyevent@*:expired)这个topic,会对cpu产生性能影响(可忽略不计,不必担心),要使用redis的key过期通知功能,就得更改配置:
1.更改config,默认关闭,打开注释就行
notify-keyspace-events Ex
2.连接redis-cli之后,输入以下命令:
config set notify-keyspace-events Ex
3.重启redis服务
二、添加依赖
1、添加maven依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
2、配置文件编写
#端口号
server:
port: 8001
tomcat:
uri-encoding: UTF-8
spring:
redis:
host: 10.0.1.51
password:
port: 6379
jedis:
pool:
max-idle: 100
min-idle: 1
max-wait:
max-active: 1000
三、编写代码
1、新增RedisListenerConfig类
@Configuration
public class RedisListenerConfig {
/**
* 注销的代码意思是:指定哪个具体的db库,默认是检测所有db,例如注释中检测的是db0
* @param connectionFactory Redis连接的线程安全工厂。
* @return RedisMessageListenerContainer
*/
@Bean
RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {
RedisMessageListenerContainer container = new RedisMessageListenerContainer();
container.setConnectionFactory(connectionFactory);
// container.addMessageListener(new RedisExpiredListener(), new PatternTopic("__keyevent@0__:expired"));
return container;
}
}
2、新增RedisKeyExpirationListener类,主要处理业务逻辑
@Component
@Slf4j
public class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {
public RedisKeyExpirationListener(RedisMessageListenerContainer listenerContainer) {
super(listenerContainer);
}
/**
* 针对redis数据失效事件,进行数据处理,需要注意的是只能获取到过期的key,value无法获取
* @param message 消息
* @param pattern 图案 - 模式匹配的信道(如果指定) - 可以为空。
*/
@Override
public void onMessage(Message message, byte[] pattern) {
String expiredKey = message.toString();
log.info("redisKey:{}过期",expiredKey);
//可以写自己的业务逻辑代码
}
}
四、测试
启动springboot项目,然后连接redis服务端,使用以下命令:
PSUBSCRIBE __keyevent@0__:expired
再开个窗口设置key,设置过期时间:
当key时间到期后可以看到第一个窗口:
可以看到刚才设置的key打印出来了,再次查看项目运行日志:
可以看到刚才代码里打出来的日志在控制器显示了
源码地址:
gitee源码地址
底下redis文件夹底下的 redis-expiration-notice 单台redis监听获取过期的key
注意:
只能监听过期key,监听不到具体value,所以需要好好设计具体key,集群会在下篇文章中