spring boot redis中的key失效监听的问题解决
1、spring boot连接配置redis参考这篇文章
https://www.jb51.net/program/339977yti.htm
2、首先开启redis的事件失效推送功能,如果是redis容器启动,参考下面的方式启动容器
docker run --restart=always -itd --name redis -p 6379:6379 redis redis-server --notify-keyspace-events Ex --requirepass xxxxxx
然后在redis客户端下面使用如下方式验证
CONFIG GET notify-keyspace-events
3、在spring boot 中新建服务类RedisKeyExpirationListener,用于捕捉获取redis中的key失效
package com.example.redis_sub.config;
import lombok.extern.slf4j.Slf4j;
import org.springframework.data.redis.connection.Message;
import org.springframework.data.redis.listener.KeyExpirationEventMessageListener;
import org.springframework.data.redis.listener.RedisMessageListenerContainer;
import org.springframework.stereotype.Component;
@Slf4j
@Component
public class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {
public RedisKeyExpirationListener(RedisMessageListenerContainer listenerContainer) {
super(listenerContainer);
}
@Override
public void onMessage(Message message, byte[] pattern) {
// 用户做自己的业务处理即可,注意message.toString()可以获取失效的key
System.out.println("key失效");
String expiredKey = message.toString();
System.out.println(expiredKey);
System.out.println(new String(pattern));
//业务逻辑
}
}
4、新建配置类RedisConfig
package com.example.redis_sub.config;
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.PatternTopic;
import org.springframework.data.redis.listener.RedisMessageListenerContainer;
@Configuration
public class RedisConfig {
@Bean
RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {
RedisMessageListenerContainer container = new RedisMessageListenerContainer();
container.setConnectionFactory(connectionFactory);
// 事件以__keyevent@<db>__为前缀进行发布
// container.addMessageListener(new RedisKeyExpirationListener(container), new PatternTopic("__keyevent@0__" +
// ":expired"));
container.addMessageListener(new RedisKeyExpirationListener(container), new PatternTopic("__keyevent@0__" +
":expired"));
return container;
}
}
到此这篇关于spring boot redis中的key失效监听的问题解决的文章就介绍到这了,更多相关springboot redis key失效内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
application.yml文件中如何开启mybatis自动驼峰映射
这篇文章主要介绍了application.yml文件中开启mybatis自动驼峰映射的方法,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-08-08
Java LocalDateTime获取时间信息、格式化、转换为数字时间戳代码示例
其实我们在Java项目中对日期进行格式化,主要是利用一些日期格式化类,下面这篇文章主要给大家介绍了关于Java LocalDateTime获取时间信息、格式化、转换为数字时间戳的相关资料,需要的朋友可以参考下2023-11-11
Springboot+Shiro+Mybatis+mysql实现权限安全认证的示例代码
Shiro是Apache 的一个强大且易用的Java安全框架,执行身份验证、授权、密码学和会话管理,Shiro 主要分为两个部分就是认证和授权两部分,这篇文章主要介绍了Springboot+Shiro+Mybatis+mysql实现权限安全认证的示例代码,需要的朋友可以参考下2024-07-07


最新评论