共计 1286 个字符,预计需要花费 4 分钟才能阅读完成。
我的项目中有些场景须要监听 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; | |
@Configuration | |
public class RedisListenerConfig { | |
@Bean | |
RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {RedisMessageListenerContainer container = new RedisMessageListenerContainer(); | |
container.setConnectionFactory(connectionFactory); | |
return container; | |
} | |
} |
3、创立 redis 过期监听
@Component | |
public 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 公布!
正文完