Redis部分设置
修改配置文件redis.conf(Windows为redis.windows.conf)
- 打开该配置文件(位置取决于自己的安装位置),找到Event notification部分。
- 将notify-keyspace-events Ex的注释打开或者添加该配置,其中E代表Keyevent,此种通知会返回key的名字,x代表超时事件。
- 如果notify-keyspace-events ""配置没有被注释的话要注释掉,否则不会生效。
- 保存后重启redis,一定要使用当前配置文件重启,例如src/redis-server redis.conf
SpringBoot部分设置
添加redis依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
在全局配置文件application中添加redis配置
spring.redis.host = localhost
spring.redis.port=6379
spring.redis.database=0
spring.redis.listen-pattern = __keyevent@0__:expired
listen-pattern填写超时时间,意思为springboot将监听redis发出的超时键空间通知。下划线前面的0代表redis的0号数据库。
创建listener
public class TopicMessageListener implements MessageListener {
@Override
public void onMessage(Message message, byte[] bytes) {
byte[] body = message.getBody();
byte[] channel = message.getChannel();
System.out.println(new String(body));
System.out.println(new String(channel));
}
}
其中message为redis返回的通知,body为超时的key的名字,channel为超时事件
创建listener配置类
@Configuration
public class RedisListenerConfiguration {
//将listener注入到容器中,防止调用被管理的bean出现空指针
@Bean
public TopicMessageListener getTopicListener(){
return new TopicMessageListener();
}
@Bean
public RedisMessageListenerContainer getListenerContainer(RedisConnectionFactory connectionFactory){
//创建连接容器
RedisMessageListenerContainer container = new RedisMessageListenerContainer();
//放入redis连接
container.setConnectionFactory(connectionFactory);
//写入需要被监听的类型,即超时监听
Topic topic = new PatternTopic("__keyevent@0__:expired");
container.addMessageListener(getTopicListener(), topic);
return container;
}
}
之后当有键值过期时,redis会发送通知被上面的TopicMessageListener接收,在该类中即可调用对应的业务方法进行业务处理。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。