我的项目中有些场景须要监听redis中的过期事件,如订单过期等场景,以Spring boot为例,大抵写下代码。

1、援用redis的包
<dependency>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-data-redis</artifactId></dependency>
2、配置redis监听容器
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;@Configurationpublic class RedisListenerConfig {    @Bean    RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {        RedisMessageListenerContainer container = new RedisMessageListenerContainer();        container.setConnectionFactory(connectionFactory);        return container;    }}
3、创立redis过期监听
@Componentpublic class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {    @Override    public void onMessage(Message message, byte[] pattern) {        // 过期key        String expiredKey = message.toString();        System.out.println(expiredKey + "过期了");        // 上面能够通过redis工具获取值或者执行业务逻辑    }    public RedisKeyExpirationListener(RedisMessageListenerContainer redisMessageListenerContainer ){        super(redisMessageListenerContainer);    }}
4、测试是否可行

这个时候你能够搞个api测试下,设置过期事件为30秒,看下当key过期时,是否会失常被监听到。

5、注意事项

留神:监听器能监听到redis中过期的key是有个要求的,必须在redis配置文件外面设置可能监听到key过期事件,配置文件去目录下找,配置如下:

本文由博客一文多发平台 OpenWrite 公布!