SpringBoot 监听Redis键过期事件 过期监听

介绍

Redis 键过期事件是 Redis 中非常有用的功能,可以在键过期时触发事件通知。这对于缓存失效、会话管理、定时任务等场景非常有用。

Redis配置

Redis 默认是没有启用键过期事件通知的,你需要通过配置来启用这个功能。可以通过修改 redis.conf 文件或者使用 CONFIG SET 命令来启用键过期事件通知。

java 复制代码
notify-keyspace-events Ex

依赖

xml 复制代码
<!--        操作redis-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

配置文件

yml 复制代码
spring:
  redis:
    host: localhost
    port: 6379
    #password: 用的本机的redis,并且我没有设置redis密码
    database: 0
    lettuce:
      pool:
        # 最大阻塞等待时间,负数表示没有限制
        max-wait: -1
        # 连接池中的最大空闲连接
        max-idle: 5
        # 连接池中的最小空闲连接
        min-idle: 0
        # 连接池中最大连接数,负数表示没有限制

写入键

java 复制代码
@RestController
@RequiredArgsConstructor
public class BasicController {
    private final StringRedisTemplate stringRedisTemplate;
    @GetMapping("/hello")
    public String hello() {
        // 设置键值对,并指定过期时间为 10 秒
        stringRedisTemplate.opsForValue().set("product:123", "dpc", Duration.ofSeconds(5));
        // 获取值
        String str = stringRedisTemplate.opsForValue().get("name");
        System.out.println("Value: " + str);
        return str;
    }
}

配置监听器

sql 复制代码
@Configuration
public class RedisListenerConfig {

    @Bean
    public RedisMessageListenerContainer redisMessageListenerContainer(RedisConnectionFactory connectionFactory) {
        RedisMessageListenerContainer container = new RedisMessageListenerContainer();
        container.setConnectionFactory(connectionFactory);
        return container;
    }

    @Bean
    public OrderKeyExpirationListener orderKeyExpirationListener(RedisMessageListenerContainer container) {
        // 配置监听器只监听 `order:*` 键
        OrderKeyExpirationListener listener = new OrderKeyExpirationListener(container);
        container.addMessageListener(listener, new ChannelTopic("__keyevent@0__:expired"));
        return listener;
    }

    @Bean
    public SessionKeyExpirationListener sessionKeyExpirationListener(RedisMessageListenerContainer container) {
        // 配置监听器只监听 `session:*` 键
        SessionKeyExpirationListener listener = new SessionKeyExpirationListener(container);
        container.addMessageListener(listener, new ChannelTopic("__keyevent@0__:expired"));
        return listener;
    }

    @Bean
    public ProductKeyExpirationListener productKeyExpirationListener(RedisMessageListenerContainer container) {
        // 配置监听器只监听 `product:*` 键
        ProductKeyExpirationListener listener = new ProductKeyExpirationListener(container);
        container.addMessageListener(listener, new ChannelTopic("__keyevent@0__:expired"));
        return listener;
    }


}

按KEY监听

监听session键

sql 复制代码
@Slf4j
public class SessionKeyExpirationListener extends KeyExpirationEventMessageListener {

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

    @Override
    public void onMessage(Message message, byte[] pattern) {
        String key = message.toString();
        if (key.startsWith("session:")) {
            log.info("会话【" + key + "】已过期");
            // 处理会话超时的逻辑
        }
    }
}

监听product键

sql 复制代码
@Slf4j
public class ProductKeyExpirationListener extends KeyExpirationEventMessageListener {
    public ProductKeyExpirationListener(RedisMessageListenerContainer listenerContainer) {
        super(listenerContainer);
    }
    @Override
    public void onMessage(Message message, byte[] pattern) {
        String key = message.toString();
        if (key.startsWith("product:")) {
            log.info("产品【" + key + "】已过期");
            // 处理产品相关的超时逻辑
        }
    }
}

监听order键

sql 复制代码
public class OrderKeyExpirationListener extends KeyExpirationEventMessageListener {

    public OrderKeyExpirationListener(RedisMessageListenerContainer listenerContainer) {
        super(listenerContainer);
    }
    @Override
    public void onMessage(Message message, byte[] pattern) {
        String key = message.toString();
        System.out.println(123);
        if (key.startsWith("order:")) {
            // 处理订单相关的超时逻辑
        }
    }
}
相关推荐
漂流瓶66666631 分钟前
Scala的模式匹配变量类型
开发语言·后端·scala
夏天吃哈密瓜36 分钟前
Scala中的正则表达式01
大数据·开发语言·后端·正则表达式·scala
2401_8337880538 分钟前
Scala的模式匹配(2)
java·开发语言
宋冠巡1 小时前
Spring Boot Validation 封装自定义校验注解和校验器(validation-spring-boot-starter)
spring boot·参数校验·validation
悠悠龙龙2 小时前
框架模块说明 #05 权限管理_03
java·开发语言·spring
开心羊咩咩3 小时前
Idea 2024.3 突然出现点击run 运行没有反应,且没有任何提示。
java·ide·intellij-idea
waterme1onY3 小时前
IDEA中MAVEN的一些设置问题
java·maven·intellij-idea
阿华的代码王国3 小时前
【算法】——前缀和(矩阵区域和详解,文末附)
java·开发语言·算法·前缀和
梦.清..3 小时前
面向对象(二)——类和对象(上)
java
Mercury_@224 小时前
JAVA设计模式,责任链模式
java·设计模式