Redis过期监听机制 (Windows)
一、功能介绍
1. redis过期监听:当数据设置了过期时间,redis会根据某些机制去时时监听过期的数据
2. 应用场景: 商城中未支付过期的订单、通知(当然也可以用redis的延迟)等等
3.本篇文章只限于Windows,Linux配置差不多,只是操作系统不同
二、redis过期监听的配置
- 在redis安装的目录下找到redis.windows.conf文件
- 编辑redis.windows.conf找到配置文件中notify-keyspace-events " " 的值,
修改为notify-keyspace-events Ex(如图下)
- 关闭redis启动窗口,在redis安装的目录下找到start.bat重启redis (如图下)
- 在SpringBoot集成使用
1、引入redis相关依赖(如图下)
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
2、创建配置类RedisListenerConfig
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.listener.RedisMessageListenerContainer;
import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;
/**
* @date 2023-02-21
* @author LIZAN
*/
@Configuration
public class RedisListenerConfig {
@Autowired
private RedisTemplate redisTemplate;
/**
* 处理乱码
* @return
*/
@Bean
public RedisTemplate redisTemplateInit() {
// key序列化
redisTemplate.setKeySerializer(new StringRedisSerializer());
//val实例化
redisTemplate.setValueSerializer(new GenericJackson2JsonRedisSerializer());
return redisTemplate;
}
@Bean
RedisMessageListenerContainer container(RedisConnectionFactory connectionFactory) {
RedisMessageListenerContainer container = new RedisMessageListenerContainer();
container.setConnectionFactory(connectionFactory);
return container;
}
}
3、继承KeyExpirationEventMessageListener创建redis过期事件的监听类,实现onMessage方法接收过去redis数据
import lombok.extern.slf4j.Slf4j;
import org.springframework.data.redis.connection.Message;
import org.springframework.data.redis.listener.KeyExpirationEventMessageListener;
import org.springframework.data.redis.listener.RedisMessageListenerContainer;
import org.springframework.stereotype.Component;
/**
* @author LiZan
* @version 1.0
* @date 2023/2/21 14:09
*/
@Slf4j
@Component
public class RedisKeyExpirationListener extends KeyExpirationEventMessageListener {
public RedisKeyExpirationListener(RedisMessageListenerContainer listenerContainer) {
super(listenerContainer);
}
/**
* 针对redis数据失效事件,进行数据处理
* @param message 失效的key
*/
@Override
public void onMessage(Message message, byte[] pattern) {
log.info("过期redis数据:" + message.toString());
try {
String key = message.toString();
//从失效key中筛选代表订单失效的key
String orderWithKey = "order_";
if (null != key && orderWithKey.startsWith(key)) {
log.info("订单号为【" + 123456 + "】超时未支付-自动修改为已取消状态");
}
} catch (Exception e) {
e.printStackTrace();
log.error("【修改支付订单过期状态异常】:" + e.getMessage());
}
}
}
4、测试Redis过期监听,在redis安装的目录下找到redis-cli.exe 打开后执行redis语法写入五秒后过期的测试数据,SET order_no123213 123 EX 5
5、数据过期后,进入Redis过期监听方法,打印过期数据从而实现业务