【RabbitMQ】09-取消超时订单

  • 生产者完成创建订单和扣减库存之后,发送消息到延迟队列。
java 复制代码
// 3.清理购物车商品
        cartClient.deleteCartItemByIds(itemIds);
        // cartService.removeByItemIds(itemIds);

        // 4.扣减库存
        try {
            itemClient.deductStock(detailDTOS);
            //itemService.deductStock(detailDTOS);
        } catch (Exception e) {
            throw new RuntimeException("库存不足!");
        }

        // 5.TODO发送延迟消息,检查用户是否已经支付完成
        rabbitTemplate.convertAndSend(MQConstants.DELAY_EXCHANGE_NAME,
                MQConstants.DELAY_ORDER_KEY,
                order.getId(),
                message -> {
                    message.getMessageProperties().setDelay(10000);
                    return message;
                });
  • 消费者监听消息,先查订单状态,没支付在查支付信息。
java 复制代码
@Slf4j
@Component
@AllArgsConstructor
public class OrderDelayMessageListener {

    private final IOrderService orderService;
    private final PayClient payClient;

    @RabbitListener(bindings = @QueueBinding(
            value = @Queue(name = MQConstants.DELAY_ORDER_QUEUE_NAME),
            exchange = @Exchange(name = MQConstants.DELAY_EXCHANGE_NAME, delayed = "true"),
            key = MQConstants.DELAY_ORDER_KEY
    ))
    public void listenOrderDelayMessage(Long orderId) {
        // 1.查询订单状态
        Order order = orderService.getById(orderId);

        // 2.检测订单状态,判断是否已支付
        if(order == null || order.getStatus()!=1) {
            log.info("delayMQ:用户已支付订单【{}】",orderId);
            return;
        }

        // 3.未支付,查询订单流水
        PayOrderDTO payOrder = payClient.queryPayOrderByBizOrderNo(orderId);

        // 4.判断是否支付
        if (payOrder == null || payOrder.getStatus() == 3) {
            // 4.1 已支付,标记订单状态已支付
            orderService.markOrderPaySuccess(orderId);
            log.info("delayMQ:已更新订单【{}】",orderId);
        } else {
            // 4.2 未支付,取消订单,恢复库存
            orderService.cancelOrder(orderId);
            log.info("delayMQ:已取消订单【{}】",orderId);
        }
    }
}
相关推荐
群联云防护小杜5 小时前
构建分布式高防架构实现业务零中断
前端·网络·分布式·tcp/ip·安全·游戏·架构
爱吃面的猫5 小时前
大数据Hadoop之——Flink1.17.0安装与使用(非常详细)
大数据·hadoop·分布式
上上迁7 小时前
分布式生成 ID 策略的演进和最佳实践,含springBoot 实现(Java版本)
java·spring boot·分布式
长路 ㅤ   7 小时前
Java后端技术博客汇总文档
分布式·算法·技术分享·编程学习·java后端
暗影八度9 小时前
Spark流水线数据质量检查组件
大数据·分布式·spark
CodeWithMe10 小时前
【Note】《Kafka: The Definitive Guide》 第5章:深入 Kafka 内部结构,理解分布式日志系统的核心奥秘
分布式·kafka
CodeWithMe10 小时前
【Note】《Kafka: The Definitive Guide》第一章:Meet Kafka
分布式·kafka
CodeWithMe10 小时前
【Note】《Kafka: The Definitive Guide》 第二章 Installing Kafka:Kafka 安装与运行
分布式·kafka
星图易码13 小时前
能源管理综合平台——分布式能源项目一站式监控
分布式·能源
CodeWithMe15 小时前
【Note】《Kafka: The Definitive Guide》 第8章: Cross-Cluster Data Mirroring
分布式·kafka