Spring Redis 监听键的过期

监听器

// redis 监听键的过期有两种方式,第二种需要解决循环依赖,此处选择第一种
@Slf4j
@Component
public class KeyExpirationListener extends KeyExpirationEventMessageListener {


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

    @Override
    public void onMessage(Message message, byte[] pattern) {
        String string = message.toString();
        log.info("key:" + string);
        //  进行过期处理,此处略,Spring 监听 key 的过期只能返回键,若需要值需要进行
        //  一次拷贝,然后将它删除
    }
}
@Configuration
public class RedisConfig {
    @Bean
    public RedisConnectionFactory redisConnectionFactory() {
        // JedisConnectionFactory 在部分版本会产生冲突,此处使用 LettuceConnectionFactory
        return new LettuceConnectionFactory();  
    }

    @Bean
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
        RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(redisConnectionFactory);
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<>(Object.class));
        return redisTemplate;
    }

    @Bean
    public RedisMessageListenerContainer redisMessageListenerContainer() {
        return new RedisMessageListenerContainer();
    }

    @Bean
    public KeyExpirationListener keyExpirationListener() {
        // keyExpirationListener 本质上是一个订阅了 __keyevent@*__:expired 的 topic
        return new KeyExpirationListener(redisMessageListenerContainer());
    }
}
  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Redis集群中,可以通过配置Spring提供的监听器来捕获过期事件。当某个过期时,可以触发相应的操作。 为了实现过期监听,在Spring Redis集群中,需要进行以下几个步骤: 1. 首先,在Spring配置文件中配置RedisTemplate,并设置监听器: ```xml <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate"> <property name="connectionFactory" ref="jedisConnectionFactory" /> <!-- 设置过期监听器 --> <property name="keyExpirationEventMessageListener" ref="keyExpirationListener" /> </bean> <bean id="keyExpirationListener" class="org.springframework.data.redis.listener.KeyExpirationEventMessageListener"> <constructor-arg ref="redisMessageListenerAdapter" /> </bean> ``` 2. 接下来,需要定义一个消息监听器: ```java public class KeyExpirationMessageListener extends KeyExpirationEventMessageListener { public KeyExpirationMessageListener(RedisMessageListenerContainer listenerContainer) { super(listenerContainer); } @Override public void onMessage(Message message, byte[] pattern) { // 处理过期事件的逻辑 String expiredKey = message.toString(); // 进行相应的处理 // ... } } ``` 3. 最后,需要配置消息监听容器: ```java @Configuration public class RedisMessageListenerConfiguration { @Bean RedisMessageListenerContainer redisMessageListenerContainer(JedisConnectionFactory jedisConnectionFactory, KeyExpirationMessageListener keyExpirationMessageListener) { RedisMessageListenerContainer container = new RedisMessageListenerContainer(); container.setConnectionFactory(jedisConnectionFactory); container.addMessageListener(keyExpirationMessageListener, new PatternTopic("__keyevent@*__:expired")); return container; } } ``` 通过以上步骤,当Redis集群中的某个过期时,就会触发监听器中定义的逻辑。可以在逻辑中进行相应的处理,比如刷新缓存或者删除相关数据等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值