电商后台--订单模块搭建

简介:        订单模块对于电商系统来说属于几大核心模块之一,其重要成都不言而喻,其中各大电商企业的业务实现方式而言基本也都是大同小异的。        正常订单逻辑中,订单的状态可大致分为这几个部分,已下单、待付款-》同步付款成功-》异步付款成功-》订单成功调用物流服务,这一个就是比较简单的订单状态,属于开启的一个比较小的服务,对于一些库存扣减这种业务正常逻辑订单暂时不考虑。

       订单模块对于电商系统来说属于几大核心模块之一,其重要成都不言而喻,其中各大电商企业的业务实现方式而言基本也都是大同小异的。

        正常订单逻辑中,订单的状态可大致分为这几个部分,已下单、待付款-》同步付款成功-》异步付款成功-》订单成功调用物流服务,这一个就是比较简单的订单状态,属于开启的一个比较小的服务,对于一些库存扣减这种业务正常逻辑订单暂时不考虑。简单说一下这几个状态,一般电商网站中,订单和支付两个服务是分别独立的,用户正常使用是先下单,生成订单之后再进行支付,这里的支付方式我们选用支付宝支付和微信支付举例说明,在app端,用户调用支付sdk支付成功之后,app会返回一个支付成功标识,这个属于同步支付成功,但是这种状态意义不大,只能算是发送成功,具体金额是否真正到账,还需要第三方进行异步通知,接收到异步通知才算是真正的付款成功。

对于订单状态的同步业务,可以考虑这样设计:

img_1b2beac6dd92ef63b900bd154a5d3c34.png

1、用户点击下单,调用结算服务,计算商品需要付款的总数值(包含各种活动之后的总数值);

2、计算完数值之后调用接单服务;

3、将订单存储到订单Redis和订单队列表,订单队列表可以按照需求水平扩展多个表,通过订单缓冲表提升接单能力,此时订单还未完全存储到数据库中,而只是放入队列中;

4,5、然后通过同步worker同步到订单中心表中,同步过程就是订单存储数据库的过程,这里通过队列的方式进行削峰;

6、此时等待用户支付的异步状态返回,当订单状态机接收到用户支付成功的通知,   便去通知存储订单的redis和数据库

7、订单数据更新,分别为redis中和数据库中的数据状态更新

这里是关于微服务搭建的订单系统,当然对于一些简单的小型系统,订单服务可以直接综合在一块,图中的第七步可以通过spring的事件监听机制进行处理,,除了解耦,还有就是,付款成功之后处理的业务逻辑一般会比较多,用这种方法能够将业务分离开,便于后期更改。

上述业务逻辑参考张开涛的《亿级流量网站架构核心技术》一书中,在此推荐这本书

相关文章
|
4月前
|
存储 前端开发 NoSQL
电商4.0项目【三】: 用户模块(8081)
电商4.0项目【三】: 用户模块(8081)
74 0
|
7月前
|
XML JSON API
要使用API接口获取淘宝电商平台的数据,您需要遵循以下步骤:
了解API文档和规范:首先,您需要了解淘宝电商平台的API文档和规范,以确定可用的接口和参数。您可以在淘宝开放平台的官方文档中找到这些信息。
|
2月前
|
监控 供应链 API
为多渠道销售集成商品API接口的正式步骤指南
摘要: 在当今的零售环境中,企业通过多渠道销售策略来扩大市场覆盖范围并提高客户接触率。商品API接口的集成是实现这一目标的关键技术手段之一。本文旨在提供一套系统的步骤指南,帮助企业高效地为其多渠道销售体系集成商品API接口。
|
8月前
|
SQL 前端开发
创建订单【项目 商城】
创建订单【项目 商城】
35 0
|
5月前
|
SQL
淘东电商项目(55) -支付系统核心表设计
淘东电商项目(55) -支付系统核心表设计
50 0
|
5月前
|
关系型数据库 MySQL 数据库
淘东电商项目(16) -会员注册功能
淘东电商项目(16) -会员注册功能
44 0
|
5月前
|
设计模式 Java Maven
淘东电商项目(60) -聚合支付(集成支付宝)
淘东电商项目(60) -聚合支付(集成支付宝)
42 0
|
5月前
|
前端开发 NoSQL 数据库
淘东电商项目(25) -门户注册功能
淘东电商项目(25) -门户注册功能
21 0
|
6月前
|
前端开发 JavaScript
27分布式电商项目 - 商品录入(基本功能)
27分布式电商项目 - 商品录入(基本功能)
36 0
|
6月前
|
消息中间件 NoSQL Java
81分布式电商项目 - 用户注册
81分布式电商项目 - 用户注册
24 0