redis key失效監聽事件


redis key失效監聽事件
創建一個監聽配置類RedisListenerConfig


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.RedisMessageListenerContainer;

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

創建一個監聽類RedisKeyExpiredListener


import cn.hutool.core.util.StrUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.connection.Message;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.listener.KeyExpirationEventMessageListener;
import org.springframework.data.redis.listener.RedisMessageListenerContainer;
import org.springframework.data.redis.serializer.RedisSerializer;
import org.springframework.stereotype.Component;

@Component
public class RedisKeyExpiredListener extends KeyExpirationEventMessageListener  {
    @Autowired
    public RedisTemplate<String, String> redisTemplate;

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

    /**
     * redis 失效監聽
     * 監聽key包含的
     *
     * @param message
     * @param bytes
     */
    @Override
    public void onMessage(Message message, byte[] bytes) {
        RedisSerializer<?> serializer = redisTemplate.getValueSerializer();
        String channel = String.valueOf(serializer.deserialize(message.getChannel()));
        String format = StrUtil.format("__keyevent@{}__:expired", "1");
        //獲取失效key名稱
        String expireKey = String.valueOf(serializer.deserialize(message.getBody()));
        System.out.println("獲取失效key名稱" + expireKey);
        if (expireKey.contains("key名稱")) {
            //在這里處理相關的業務
        }
    }
}

創建一個測試代碼

    @GetMapping(value = "/expiredTest")
    public void redisTest() {
        redisTemplate.opsForValue().set("test", "值", 5, TimeUnit.SECONDS);
    }

key失效監聽業務處理


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM