订单超时设计(1)--- 如何使用redis实现订单超时实时关闭功能

如何使用redis实现订单超时实时关闭功能

  • 准备工作
  • 实现步骤
  • 解释
  • 注意事项(重点)

使用Redis实现订单超时实时关闭功能,可以利用Redis的延时队列(使用Sorted Set实现)和过期键(使用TTL和Keyspace Notifications)来实现。以下是一个示例说明如何实现这个功能。

准备工作

首先,需要确保你的Redis服务器已经开启了Keyspace Notifications功能。你可以在Redis的配置文件中设置以下参数,或者在Redis CLI中执行命令:

# 在redis.conf中设置
notify-keyspace-events Ex

或者在Redis CLI中执行:

CONFIG SET notify-keyspace-events Ex

实现步骤

  1. 创建订单并设置过期时间:当用户创建订单时,将订单信息存储在Redis中,并设置一个过期时间(例如30分钟)。

  2. 监听订单过期事件:使用Redis的Keyspace Notifications功能监听订单的过期事件,当订单过期时执行相应的关闭操作。

  3. 处理订单关闭逻辑:在订单过期时,将订单状态设置为已取消,并进行相应的业务处理。

下面是一个简单的Java示例,使用Jedis库来实现:

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPubSub;

public class OrderService {
    private static final String REDIS_HOST = "localhost";
    private static final int REDIS_PORT = 6379;
    private static final int ORDER_EXPIRE_TIME = 30 * 60; // 30 minutes in seconds

    private Jedis jedis;

    public OrderService() {
        this.jedis = new Jedis(REDIS_HOST, REDIS_PORT);
    }

    // 创建订单
    public void createOrder(String orderId) {
        // 存储订单信息到Redis,并设置过期时间
        jedis.setex("order:" + orderId, ORDER_EXPIRE_TIME, "PENDING");
        System.out.println("Order " + orderId + " created and will expire in 30 minutes.");
    }

    // 监听订单过期事件
    public void startOrderExpirationListener() {
        new Thread(() -> {
            try (Jedis jedis = new Jedis(REDIS_HOST, REDIS_PORT)) {
                jedis.psubscribe(new JedisPubSub() {
                    @Override
                    public void onPMessage(String pattern, String channel, String message) {
                        if (channel.equals("__keyevent@0__:expired")) {
                            handleOrderExpiration(message);
                        }
                    }
                }, "__keyevent@0__:expired");
            }
        }).start();
    }

    // 处理订单过期
    private void handleOrderExpiration(String orderKey) {
        if (orderKey.startsWith("order:")) {
            String orderId = orderKey.substring(6);
            System.out.println("Order " + orderId + " has expired and will be cancelled.");
            // 更新订单状态为已取消(在实际应用中,这里可以是数据库操作)
            // updateOrderStatus(orderId, "CANCELLED");
        }
    }

    public static void main(String[] args) throws InterruptedException {
        OrderService orderService = new OrderService();
        orderService.startOrderExpirationListener();

        // 创建一个示例订单
        orderService.createOrder("12345");

        // 保持主线程运行一段时间以便观察过期事件
        Thread.sleep(35 * 60 * 1000);
    }
}

解释

  1. 创建订单:在 createOrder 方法中,我们将订单信息存储在Redis中,并使用 setex 方法设置订单的过期时间为30分钟。

  2. 监听订单过期事件:在 startOrderExpirationListener 方法中,我们使用 psubscribe 方法监听Redis的过期事件。当订单过期时,Redis会发布一个过期事件,我们可以在 onPMessage 方法中处理这个事件。

  3. 处理订单过期:在 handleOrderExpiration 方法中,我们处理订单过期的逻辑,例如将订单状态设置为已取消。在实际应用中,这里可以是数据库操作。

  4. 运行示例:在 main 方法中,我们创建一个示例订单,并保持主线程运行一段时间以便观察过期事件。

这个示例展示了如何使用Redis实现订单超时实时关闭功能。在实际应用中,你可能需要根据具体需求进行扩展和优化,例如处理并发、错误处理和日志记录等。

注意事项(重点)

== 1.Keyspace Notifications无法实现事件的可靠通知。==
Keyspace Notifications功能是Redis从2.8.0版本开始支持的一项功能,它基于订阅/发布(Pub/Sub)机制,允许客户端接收Redis数据空间中键变化的事件通知‌。
Keyspace Notifications可以监控Redis中的键和值的变化,包括键的过期事件。当库中的键发生改变时,如添加、修改、删除或过期等,订阅了相应事件的客户端可以立即接收到通知。这一功能通过Pub/Sub频道实现,客户端需要订阅特定的频道来感知事件的发生。
值得注意的是,Redis的Pub/Sub功能是“触发后不管(Fire and Forget)”的,即如果发布/订阅的客户端断开连接,然后再重新连接,那么在客户端断开连接的期间内传递的所有事件都会丢失。因此,Keyspace Notifications无法实现事件的可靠通知。不过,Redis的未来版本可能会计划支持事件的可靠通知功能‌。
2.在分布式环境下要注意不能重复处理订单。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/967409.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

重启电脑之后vscode不见了

某天重启电脑之后发现vscode被删除 双击发现是 后面追溯到文件夹下面发现有一个文件夹的名字叫_ 把这个文件夹打开发现之前的包全在这里面 只需要把这个包里面的文件全部移到上一级即可

高级加密标准AES候选算法之一Crypton

目录 (1)轮密钥加 (2)列混合变换 (3)字节替代变换 (4)字节置换变换 Crypton的加密算法 Crypton的解密算法 密钥扩展算法 高级加密标准AES候选算法之一Crypton Crypton算法是由Chae Hoon Lim于1998年设计的,它是被接受为AES侯选者的15种分组密码之一。该算法是…

2025最新主流深度学习算法全解析

深度学习:开启智能时代的钥匙 在当今数字化时代,深度学习无疑是人工智能领域中最为耀眼的明星。它如同一把神奇的钥匙,开启了智能时代的大门,让计算机从简单的数据处理迈向了复杂的智能决策。深度学习通过构建具有多个层次的神经网…

51单片机(国信长天)矩阵键盘的基本操作

在CT107D单片机综合训练平台上,首先将J5处的跳帽接到1~2引脚,使按键S4~S19按键组成4X4的矩阵键盘。在扫描按键的过程中,发现有按键触发信号后(不做去抖动),待按键松开后,在数码管的第一位显示相应的数字:从左至右&…

如何在浏览器中搭建开源Web操作系统Puter的本地与远程环境

文章目录 前言1.关于Puter2.本地部署Puter3.Puter简单使用4. 安装内网穿透5.配置puter公网地址6. 配置固定公网地址 前言 嘿,小伙伴们!是不是每次开机都要像打地鼠一样不停地点击各种网盘和应用程序的登录按钮,感觉超级麻烦?更让…

【JavaScript】this 指向由入门到精通

this 的概念 this 在JavaScript 及其其他面向对象的编程语言中,存在的目的是为了提供一种在对象方法中引用当前对象的方式。 它为方法提供了对当前实例的引用,使得方法能够访问或者修改实例的成员变量。 注意点: this 的绑定和定位的位置…

javaEE-10.CSS入门

目录 一.什么是CSS ​编辑二.语法规则: 三.使用方式 1.行内样式: 2.内部样式: 3.外部样式: 空格规范 : 四.CSS选择器类型 1.标签选择器 2.类选择器 3.ID选择器 4.通配符选择器 5.复合选择器 五.常用的CSS样式 1.color:设置字体颜色 2.font-size:设置字体大小 3…

数据中台是什么?:架构演进、业务整合、方向演进

文章目录 1. 引言2. 数据中台的概念与沿革2.1 概念定义2.2 历史沿革 3. 数据中台的架构组成与关键技术要素解析3.1 架构组成3.2 关键技术要素 4. 数据中台与其他平台的对比详细解析 5. 综合案例:金融行业数据中台落地实践5.1 背景5.2 解决方案5.3 成果与价值 6. 方向…

Linux磁盘空间使用率100%(解决删除文件后还是显示100%)

本文适用于,删除过了对应的数据文件,查看还是显示使用率100%的情况 首先使用df -h命令查看各个扇区所占用的情况 一、先对系统盘下所有文件大小进行统计,是否真的是数据存储以达到了磁盘空间 在对应的扇区路径下使用du -sh * | sort -hr 命…

DeepSeek--教师备课效能100%

关键功能深度解析 深度思考(R1) 开启这个功能,就如同为 DeepSeek 赋予了深度思考的 “大脑”。当你向它咨询备课问题时,它会像经验丰富的教师一样,在 “脑海” 中梳理思路,不仅给出答案,还会展…

基于Java的自助多张图片合成拼接实战

目录 前言 一、图片合成需求描述 二、图片合成设计与实现 1、编程语言 2、基础数据准备 3、图片合成流程 4、图片合成实现 三、总结 前言 在当今数字化时代,图像处理技术在各个领域都发挥着至关重要的作用。从社交媒体到电子商务,从在线教育到虚拟…

大模型基本原理(四)——如何武装ChatGPT

传统的LLM存在几个短板:编造事实、计算不准确、数据过时等,为了应对这几个问题,可以借助一些外部工具或数据把AI武装起来。 实现这一思路的框架包括RAG、PAL、ReAct。 1、RAG(检索增强生成) LLM生成的内容会受到训练…

电控--PWM

理论知识 脉宽调制(Pulse Width Modulation,PWM) 对脉冲信号的宽度改变并输出出来高频的PWM波可以让设备进行频繁开关、通断 PWM波形的参数 周期(T):完整脉冲循环时间(单位:秒)频率(f)&…

CNN卷积神经网络多变量多步预测,光伏功率预测(Matlab完整源码和数据)

代码地址:CNN卷积神经网络多变量多步预测,光伏功率预测(Matlab完整源码和数据) 标题:CNN卷积神经网络多变量多步预测,光伏功率预测 一、引言 1.1 研究背景及意义 随着全球能源危机的加剧和环保意识的提升&#xff…

在clion中对linux的工程进行远程调试

本地主机:windows 远程主机:ubuntu 0. 建立一个用于同步远程工程代码的文件夹 在windows上新建了一个iot_frame_0210文件夹,用于远程调试,远程的代码会被下载到这个本地目录。 调试的时候,如果修改文件,则不会直接…

使用sunshine和moonlight串流时的音频输出问题

设备:电脑和平板串流,把平板当副屏使用 1.如果启用安装steam音频驱动程序,则平板有声,电脑无声,在moonlight端可以设置平板和电脑同时发声,但是有点卡 2.只想电脑发声,平板无声 禁用安装steam…

postgresql 游标(cursor)的使用

概述 PostgreSQL游标可以封装查询并对其中每一行记录进行单独处理。当我们想对大量结果集进行分批处理时可以使用游标,因为一次性处理可能造成内存溢出。 另外我们可以定义函数返回游标类型变量,这是函数返回大数据集的有效方式,函数调用者…

深入探索人工智能的未来:DeepSeek R1与蓝耘智算平台的完美结合

在当今数字化时代,人工智能(AI)和机器学习(ML)正以前所未有的速度改变着我们的生活和工作方式。从智能语音助手到自动驾驶汽车,从精准医疗到金融风险预测,AI的应用无处不在。深度学习作为AI的核…

树和二叉树_9

树和二叉树_9 一、leetcode-107二、题解1.引库2.代码 一、leetcode-107 二叉树的层序遍历Ⅱ 给你二叉树的根节点 root ,返回其节点值 自底向上的层序遍历 。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)。 样例输…

【安当产品应用案例100集】037-强化OpenVPN安全防线的卓越之选——安当ASP身份认证系统

在当前数字化时代,网络安全已成为企业发展的重要组成部分。对于使用OpenVPN的企业而言,确保远程访问的安全性尤为重要。安当ASP身份认证系统凭借其强大的功能和便捷的集成方式,为OpenVPN的二次登录认证提供了理想的解决方案,特别是…