Monitoramento expirado Redis

Monitoramento expirado Redis

Cenário de uso: Em nosso projeto, precisamos realizar operações como pedido de pagamento de horas extras, atualização de status e devolução de estoque. Aqui, o uso do monitoramento expirado do redis pode ser feito

↓↓↓下面上代码↓↓↓

Primeiro, se o monitoramento do redis for necessário para entrar em vigor, o código a seguir deve ser configurado

arquivo yml

Insira a descrição da imagem aqui

RedisListenerConfig.java

@Slf4j
@Configuration
public class RedisListenerConfig {
    
    

    @Bean
    public RedisMessageListenerContainer container(RedisConnectionFactory redisConnectionFactory) {
    
    
        RedisMessageListenerContainer container = new RedisMessageListenerContainer();
        container.setConnectionFactory(redisConnectionFactory);
        log.info("redis监听配置生效");
        return container;
    }
}

usar
RedisKeyExpirationListener.java

@Slf4j
@Configuration
public class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {
    
    

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

    private final RedisTemplate<String, String> redisTemplate;

    public RedisKeyExpirationListener(RedisMessageListenerContainer listenerContainer, RedisTemplate<String, String> redisTemplate) {
    
    
        super(listenerContainer);
        this.redisTemplate = redisTemplate;
    }

    @Override
    public void onMessage(Message message, byte[] bytes) {
    
    
        log.info("过期监听事件启动");
        RedisSerializer<?> serializer = redisTemplate.getValueSerializer();
        String channel = String.valueOf(serializer.deserialize(message.getChannel()));
        // 获取过期的Key值
        String body = String.valueOf(serializer.deserialize(message.getBody()));
        // DB0 key过期监听
        if (StrUtil.format("__keyevent@{}__:expired", redisDatabase).equals(channel)) {
    
    
            System.out.println("第" + redisDatabase + "个DB库的key过期,key:" + body);
        }
    }
}

Vamos testar isso

Insira a descrição da imagem aqui
Aguarde 30 segundos ...

O resultado é o seguinte

Insira a descrição da imagem aqui

Acho que você gosta

Origin blog.csdn.net/weixin_42825651/article/details/108714255
Recomendado
Clasificación