订单到期关闭

文章目录


前言

实习期间在做订单模块。遇到过订单到时关闭的场景。

因为我们在通过回调接收第三方订单状态的时候,使用了rocketmq,在遇到订单超时关闭的场景的时候,为了不引入额外的依赖,我们就继续使用rocketmq的延迟队列来做实现。

同时记录几种刚了解到的订单到期关闭实现方式。


一、场景?

酒店模块中,比如用户下单酒店了。

我们要设置超过多少分钟,就将订单自动取消了。

二、使用步骤

1.项目配置好rocketmq

2.读入数据

创建一个生产者

java 复制代码
public class DelayProduce {
    @Autowired
    private RocketMQTemplate rocketMQTemplate;

    /**
     * @param topic 主题
     * @param message 消息内容
     * @param delayLevel 分为18个等级,分别对应:1s 5s 10s 30s 1m 2m 3m 4m 5m 6m 7m 8m 9m 10m 20m 30m 1h 2h
     */
    public void sendDelayMessage(String topic, String message, int delayLevel) {
        SendResult sendResult = rocketMQTemplate.syncSend(topic, MessageBuilder.withPayload(message).build(), 10000L, delayLevel);
        log.info("sendtime is {}", DateTimeFormatter.ofPattern("yyyy年MM月dd日 HH:mm:ss").format(LocalDateTime.now()));
        log.info("sendResult is{}", sendResult);
    }

    public void sendCommonMessage(String topic, String message) {
        SendResult sendResult = rocketMQTemplate.syncSend(topic, MessageBuilder.withPayload(message).build(), 10000L);
        log.info("sendtime is {}", DateTimeFormatter.ofPattern("yyyy年MM月dd日 HH:mm:ss").format(LocalDateTime.now()));
        log.info("sendResult is{}", sendResult);
    }
}

创建好订单之后,将订单发送到延迟队列

java 复制代码
public class orderCreator {

    public void create( ... ) {
        
        ...

        delayProduce.sendDelayMessage(
                CERTAIN_TOPIC,
                JSON.toJSONString(order),
                15 // 15代表rocketmq中第15级的延时时长,20分钟
        );

        ...

    }
}

延时队列的消费者,来处理到时间的订单消息

java 复制代码
@RocketMQMessageListener(
        topic = TOPIC,
        consumerGroup = CONSUMERGROUP
)
public class OrderDelayConsumer implements RocketMQListener<String> {

    @Override
    public void onMessage(String message) {
        检测订单是否已经支付成功,如果支付过了,就不管了
        如果仍然没有支付,就取消订单,对订单进行关闭
        if (取消成功) {
            创建message,发送给状态机,转换订单状态为已取消
        }
    }
}

其他方式处理订单到期关闭

定时任务

通过定时任务,去定期扫描到期的订单,做关单操作。比如使用xxl-job。

这样的处理方式的优点是:

  1. 简单 实现容易

缺点也显而易见:

  1. 关单时机不精确,
相关推荐
Evand J几秒前
【MATLAB例程】基于EKF的分布式卡尔曼滤波,用于多个车辆的集群导航,融合IMU和GNSS、相对测量的UWB数据
开发语言·分布式·matlab
人间打气筒(Ada)1 分钟前
go:如何实现接口限流和降级?
开发语言·中间件·go·限流·etcd·配置中心·降级
云泽8081 分钟前
深入红黑树:SGI-STL 中 map 与 set 的关联容器架构剖析
开发语言·c++·stl底层架构
福楠2 分钟前
constexpr 全家桶
c语言·开发语言·c++
REDcker2 分钟前
C++ vcpkg:安装、使用、原理与选型
开发语言·c++·windows·操作系统·msvc·vcpkg
晓13132 分钟前
React篇——第五章 React Router实战
开发语言·javascript·ecmascript
Meepo_haha4 分钟前
Maven Spring框架依赖包
java·spring·maven
studyForMokey4 分钟前
【Android面试】ViewModel & LiveData & EventBus专题
android·java·面试
迷藏4946 分钟前
# 发散创新:用Rust构建高性能分布式账本节点——从零实现共识算法与链上数据存储
java·python·rust·共识算法·分布式账本
Flittly8 分钟前
【SpringAIAlibaba新手村系列】(5)Prompt 提示词基础与多种消息类型
java·笔记·spring·ai·springboot