Redis过期监听机制,订单超时自动取消方式
Redis过期监听机制 (Windows)
一、功能介绍
1. redis过期监听:当数据设置了过期时间,redis会根据某些机制去时时监听过期的数据
2. 应用场景: 商城中未支付过期的订单、通知(当然也可以用redis的延迟)等等
3. 本篇文章只限于Windows,Linux配置差不多,只是操作系统不同
二、redis过期监听的配置
1. 在redis安装的目录下找到redis.windows.conf文件
2. 编辑redis.windows.conf找到配置文件中notify-keyspace-events " " 的值,
修改为notify-keyspace-events Ex(如图下)
3. 关闭redis启动窗口,在redis安装的目录下找到start.bat重启redis (如图下)
4. 在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过期监听方法,打印过期数据从而实现业务
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Redis中什么是Big Key(大key)问题?如何解决Big Key问题?
大key并不是指key的值很大,而是key对应的value很大,下面这篇文章主要给大家介绍了Redis中什么是Big Key(大key)问题?如何解决Big Key问题的相关资料,需要的朋友可以参考下2023-03-03Redis Redisson lock和tryLock的原理分析
这篇文章主要介绍了Redis Redisson lock和tryLock的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-04-04
最新评论