Monitoreo caducado de Redis

Monitoreo caducado de Redis

Escenario de uso: En nuestro proyecto, necesitamos realizar operaciones tales como pago de pedidos en horas extras, actualizar el estado y devolver el inventario. Aquí, se puede usar el monitoreo caducado de redis

↓↓↓下面上代码↓↓↓

Primero, si se requiere que la supervisión de redis surta efecto, se debe configurar el siguiente código

archivo yml

Inserte la descripción de la imagen aquí

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;
    }
}

utilizar
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 a probarlo

Inserte la descripción de la imagen aquí
Espere 30 segundos ...

El resultado es el siguiente

Inserte la descripción de la imagen aquí

Supongo que te gusta

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