全教育培训行业第三方平台平台就业机构
扫码试听
扫码试听
Q:2638333071
首页 > 行业问答 > > 在淘宝上要完成一笔订单会有哪些参与者一起协同(淘宝每一笔订单收取多少费用)
行业动态 行业问答 课程问答 零基础学习 就业前景 技术干货

在淘宝上要完成一笔订单会有哪些参与者一起协同(淘宝每一笔订单收取多少费用)

发布时间:4 周 前 栏目:行业问答 浏览:

1、在淘宝上要完成一笔订单会有哪些参与者一起协同

目前常见的应用软件都有消息的延迟推送的影子,应用也极为广泛,例如:

淘宝七天自动确认收货。在我们签收商品后,物流系统会在七天后延时发送一个消息给支付系统,通知支付系统将款打给商家,这个过程持续七天,就是使用了消息中间件的延迟推送功能。

12306 购票支付确认页面。我们在选好票点击确定跳转的页面中往往都会有倒计时,代表着 30 分钟内订单不确认的话将会自动取消订单。其实在下订单那一刻开始购票业务系统就会发送一个延时消息给订单系统,延时30分钟,告诉订单系统订单未完成,如果我们在30分钟内完成了订单,则可以通过逻辑代码判断来忽略掉收到的消息。

在上面两种场景中,如果我们使用下面两种传统解决方案无疑大大降低了系统的整体性能和吞吐量:

使用 redis 给订单设置过期时间,最后通过判断 redis 中是否还有该订单来决定订单是否已经完成。这种解决方案相较于消息的延迟推送性能较低,因为我们知道 redis 都是存储于内存中,我们遇到恶意下单或者刷单的将会给内存带来巨大压力。

使用传统的数据库轮询来判断数据库表中订单的状态,这无疑增加了IO次数,性能极低。

使用 jvm 原生的 DelayQueue ,也是大量占用内存,而且没有持久化策略,系统宕机或者重启都会丢失订单信息。

消息延迟推送的实现

在 RabbitMQ 3.6.x 之前我们一般采用死信队列+TTL过期时间来实现延迟队列,我们这里不做过多介绍。

在 RabbitMQ 3.6.x 开始,RabbitMQ 官方提供了延迟队列的插件,可以下载放置到 RabbitMQ 根目录下的 plugins 下。

首先我们创建交换机和消息队列。

我们在 Exchange 的声明中可以设置exchange.setDelayed(true)来开启延迟队列,也可以设置为以下内容传入交换机声明的方法中,因为第一种方式的底层就是通过这种方式来实现的。

发送消息时我们需要指定延迟推送的时间,我们这里在发送消息的方法中传入参数 new MessagePostProcessor() 是为了获得 Message对象,因为需要借助 Message对象的api 来设置延迟时间。

我们可以观察 setDelay(Integer i)底层代码,也是在 header 中设置 x-delay。等同于我们手动设置 header

message.getMessageProperties().setHeader("x-delay", "6000");

消费端进行消费

果然在 6 秒后收到了消息 lazy receive hello spring boot:

在淘宝上要完成一笔订单会有哪些参与者一起协同

2、光遇未支付订单多久自动取消

当下了订单后10分钟或30分钟未支付,订单会自动取消,具体是如何实现的呢?本文使用最常用的几种方式,只说明关键的部分,已30分钟为例。回到顶部下单时,订单状态是侍支付。将订单编号作为Key,下单的时间戳作为Va|ue,设置过期时间是30分钟。

在淘宝上要完成一笔订单会有哪些参与者一起协同

3、订单超时,活动过期解决方案:php监听redis键重复触发引发事件

订单超时,活动过期解决方案:php监听redis键重复触发引发事件

Redis的2.8.0版本之后可用,键空间消息(Redis Keyspace Notifications),配合2.0.0版本之后的SUBSCRIBE可以完成这个定时任务的操作了,定时的单位是秒。

1.我们先订阅频道称为redisChat

2.现在,我们重新开启个redis客户端,然后在同一个频道redisChat发布消息,订阅者可以接收到消息。

接收到的消息如下:

3.Key过期事件的Redis配置

需要这里配置notify-keyspace-events的参数为“EX” .X代表了过期事件。notify-keyspace-events “Ex”保存配置后,重启Redis的服务,使配置生效。

PHP Redis实现订阅键空间通知

redis实例化类:

1个

18岁

//遇到类别重复的报错,所有叫Redis2

过期事件的订阅:

1个

// 解决Redis客户端订阅时候超时情况

// 回调函数,这里写处理逻辑

//keyCallback为订阅事件后的回调函数,这里写业务处理逻辑,

//比如前面提到的商品不支付自动撤单,这里就可以根据订单id,来实现自动撤单

设置过期事件:

1个

先用命令行模式执行psubscribe.php

在浏览器访问index.php

效果如下:

上一篇:没有了
技术干货
零基础学习
行业多年深耕,从这报名,学费立减800
  • 岳同学180****1241刚刚成功领取
  • 胡同学134****6431刚刚成功领取
  • 李同学150****6122刚刚成功领取
  • 张同学136****2231刚刚成功领取
  • 孙同学178****5521刚刚成功领取
  • 齐同学156****7788刚刚成功领取
猜你喜欢
查看更多
相关推荐
查看更多
现在学习,我的薪资能达到多少?
立即报名

联系我们:

Q:2638333071

鄂ICP备2023015464号