若依添加添加监听容器配置(删除键,键过期)

1、配置Redis的键触发事件

bash 复制代码
# 基础配置
bind 0.0.0.0                   
# 允许所有IP连接
protected-mode no              
# 关闭保护模式(生产环境建议结合密码使用)
port 6379                      
# 默认端口
daemonize no                   
# 非后台运行(Docker 中必须为 no)
timeout 0                      
# 连接超时时间(0为不限制)
tcp-keepalive 300              
# 保持TCP连接活性
# 持久化
appendonly yes                 
# 开启AOF持久化
appendfsync everysec           
# 每秒同步一次AOF文件
dir /data                      
# 数据存储路径(Docker 中需挂载此目录)

# 内存管理
maxmemory 1GB                  
# 最大内存限制(根据需求调整)
maxmemory-policy volatile-lru  
# 内存满时删除最近最少使用的键

# 安全
requirepass 12321sadsadsadSDDSADS     
# 设置密码(生产环境必选)

# 键空间通知(关键配置!)
notify-keyspace-events Egx      
# 监听键过期事件(E: 键事件, x: 过期事件)

# 日志
loglevel notice                
# 日志级别(notice/production环境推荐)
logfile ""                     
# 日志输出到标准输出(Docker 友好)

按照配置文件进行启动

shell 复制代码
docker run -d -p 6379:6379 --name redis-server  --restart=always -v /home/redis/redis.conf:/etc/redis/redis.conf  -v /home/redis/data:/data -d redis:7.0.2 redis-server /etc/redis/redis.conf

2、 总的配置需要添加

配置文件在framework模块下面的config文件夹中

java 复制代码
@Configuration
@EnableCaching
public class RedisConfig extends CachingConfigurerSupport
{
    @Bean
    public RedisMessageListenerContainer redisMessageListenerContainer(RedisConnectionFactory connectionFactory) {
        RedisMessageListenerContainer container = new RedisMessageListenerContainer();
        container.setConnectionFactory(connectionFactory);
        return container;
    }
}

3、 键删除监听

java 复制代码
@Component
@Slf4j
public class RedisKeyDeletionListener extends KeyExpirationEventMessageListener {

    @Value("${spring.redis.database}")
    private Integer database;

    public RedisKeyDeletionListener(RedisMessageListenerContainer listenerContainer) {
        super(listenerContainer);
    }

    @Override
    protected void doRegister(RedisMessageListenerContainer listenerContainer) {
        // 监听指定数据库的键删除事件(__keyevent@*__:del)
        listenerContainer.addMessageListener(
            this,
            new PatternTopic("__keyevent@" + database + "__:del")
        );
    }

    @Override
    public void onMessage(Message message, byte[] pattern) {
        String deletedKey = new String(message.getBody());
        log.info("Key deleted: {}", deletedKey);
         //此处写你的业务逻辑
    }

}

4、 键过期监听

java 复制代码
@Component
@Slf4j
public class RedisKeyBasicExpirationListener 
				extends KeyExpirationEventMessageListener {

	// 当前服务连接的redis库序列号
    @Value("${spring.redis.database}")
    private Integer database;

    public RedisKeyBasicExpirationListener(
    	RedisMessageListenerContainer listenerContainer) {
        super(listenerContainer);
    }
    
    // 指定监听数据库
    @Override
    protected void doRegister(RedisMessageListenerContainer listenerContainer) {
        listenerContainer.addMessageListener(
        		this, new PatternTopic("__keyevent@" + database + "__:expired")
        	);

    }

    @Override
    public void onMessage(Message message, byte[] pattern) {
        // 业务逻辑执行
        System.out.println("业务逻辑执行");
        killVlcThread();
    }

}
相关推荐
阳光九叶草LXGZXJ1 天前
达梦数据库-学习-47-DmDrs控制台命令(LSN、启停、装载)
linux·运维·数据库·sql·学习
Hgfdsaqwr1 天前
掌握Python魔法方法(Magic Methods)
jvm·数据库·python
s1hiyu1 天前
使用Scrapy框架构建分布式爬虫
jvm·数据库·python
2301_763472461 天前
使用Seaborn绘制统计图形:更美更简单
jvm·数据库·python
熊文豪1 天前
金仓数据库如何以“多模融合“重塑文档数据库新范式
数据库·金仓数据库·电科金仓·mongodb迁移
霖霖总总1 天前
[小技巧56]深入理解 MySQL 聚簇索引与非聚簇索引:原理、差异与实践
数据库·mysql
Dreamboat-L1 天前
Redis及其两种持久化技术详解
数据库·redis·缓存
伐尘1 天前
【MySQL】间隙锁 与 排他锁 的区别
数据库·mysql
浒畔居1 天前
机器学习模型部署:将模型转化为Web API
jvm·数据库·python
一个响当当的名号1 天前
lectrue9 索引并发控制
java·开发语言·数据库