下单过程需要锁定库存,同时需要锁定优惠券,而库存在product微服务模块,优惠券在coupon模块,涉及到分布式事务,但是通常情况下不能使用分布式事务:
扣减库存这一步可能出现的问题:
? ? ? ? ? ? ? ? ???
?
?下单逻辑完整版,用来替代分布式事务:
?下单后创建订单(order表里面生成记录)扣减库存,
之后生成一个库存锁定记录,标注这个订单号关联的用户、商品以及买了几件,这部分信息会存储在mysql的表里面;同时会发送一个延迟消息到MQ 里面;
?创建订单、扣减库存后,会生成支付路径,等待用户支付,
// 下单记录表,coupon库中构建下单状时苏锁定优惠券的记录表
CREATE TABLE `coupon_task` (
`id` BIGINT(11) UNSIGNED NOT NULL
AUTO_INCREMENT,
`coupon_record_id` BIGINT(11) DEFAULT NULL COMMENT '优惠券记录id',
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`out_trade_no` VARCHAR(64) DEFAULT NULL COMMENT '订单号 XID',
`lock_state` VARCHAR(32) DEFAULT NULL COMMENT '锁定 LOCK- 完成FINISH 取消CANCEL',
PRIMARY KEY (`id`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;
// 在商品product库中构建锁定库存的记录表
CREATE TABLE `product_task` (
`id` BIGINT(11) UNSIGNED NOT NULL AUTO_INCREMENT,
`product_id` BIGINT(11) DEFAULT NULL COMMENT '商品id',
`buy_num` INT(11) DEFAULT NULL COMMENT '购买数量',
`product_name` VARCHAR(128) DEFAULT NULL COMMENT '商品名称',
`lock_state` VARCHAR(32) DEFAULT NULL COMMENT '锁定LOCK 完成FINISH-取消CANCEL',
`out_trade_no` VARCHAR(32) DEFAULT NULL COMMENT '订单号XID',
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;
|