开发者

Redis过期监听机制,订单超时自动取消方式

开发者 https://www.devze.com 2024-08-10 10:35 出处:网络 作者: 绝对没精神
目录一、功能介绍二、Redis过期监听的配置总结Redis过期监听机制 (Windows) 
目录
  • 一、功能介绍
  • 二、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(如图下)

Redis过期监听机制,订单超时自动取消方式

3. 关闭redis启动窗口,在redis安装的目录下找到start.BAT重启redis (如图下)

Redis过期监听机制,订单超时自动取消方式

4. 在SpringBoot集成使用

  • 1、引入redis相关依赖(如图下)
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>sprin编程客栈g-boot-starter-data-redis</artifactId>
        </dependency>

Redis过期监听机制,订单超时自动取消方式

  • 2、创建配置类RedisListenerConfig
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.conthttp://www.devze.comext.annotation.Configura编程tion;
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.springframewandroidork.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 KeyExpirationEventMessageListenewww.devze.comr {
    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

Redis过期监听机制,订单超时自动取消方式

  • 5、数据过期后,进入Redis过期监听方法,打印过期数据从而实现业务

Redis过期监听机制,订单超时自动取消方式

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程客栈(www.devze.com)。

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号