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

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

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

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

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

img_1b2beac6dd92ef63b900bd154a5d3c34.png

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

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

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

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

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

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

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

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

相关文章
|
存储 数据库
订单系统的设计
订单系统的设计
|
5月前
|
消息中间件 供应链 前端开发
如何开发供应商管理系统中的订单协同板块(附架构图+流程图+代码参考)
在现代企业供应链管理中,订单协同是连接采购、销售、供应商与库存的重要环节。本文详解供应商管理系统中订单协同板块的设计与实现,涵盖功能模块、业务流程、技术架构及代码示例,帮助企业提升供应链效率,降低库存风险,优化订单管理流程。
|
11月前
|
人工智能 数据安全/隐私保护 图形学
关于AI绘画优雅草央千澈整理的一份咒语(与AI对话提示词-应用于AI绘图和AI生成视频)-本文长期更新-本次更新2025年1月15日更新-长期更新建议点赞收藏
关于AI绘画优雅草央千澈整理的一份咒语(与AI对话提示词-应用于AI绘图和AI生成视频)-本文长期更新-本次更新2025年1月15日更新-长期更新建议点赞收藏
766 4
|
8月前
|
SQL 安全 测试技术
2025接口测试全攻略:高并发、安全防护与六大工具实战指南
本文探讨高并发稳定性验证、安全防护实战及六大工具(Postman、RunnerGo、Apipost、JMeter、SoapUI、Fiddler)选型指南,助力构建未来接口测试体系。接口测试旨在验证数据传输、参数合法性、错误处理能力及性能安全性,其重要性体现在早期发现问题、保障系统稳定和支撑持续集成。常用方法包括功能、性能、安全性及兼容性测试,典型场景涵盖前后端分离开发、第三方服务集成与数据一致性检查。选择合适的工具需综合考虑需求与团队协作等因素。
1268 24
|
运维 监控 安全
深入理解微服务架构:设计原则、挑战与实践
深入理解微服务架构:设计原则、挑战与实践
|
运维 监控 Java
系统日志规范及最佳实践
系统日志规范及最佳实践
959 1
系统日志规范及最佳实践
|
设计模式 前端开发 测试技术
软件质量的守门人——接口测试
接口作为API,是后端预定义的函数,用于系统间通信和数据交换。接口测试验证不同组件间的交互,确保其准确、可靠。常见应用场景包括集成测试、版本迭代测试、性能测试、安全测试和错误场景测试。随着服务端复杂性的增加,传统测试方法面临挑战,因此引入分层测试(如马丁福勒的测试金字塔模型)和自动化测试,以降低成本并提高效率。接口测试成为确保后端服务质量的关键,学习接口测试可从理解其价值、协议、工具使用及Mock测试等方面逐步进阶。
|
运维 测试技术 双11
什么是性能测试,一篇文章告诉你!
性能测试评估系统在现实负载下的性能和可靠性,包括响应时间、吞吐量和稳定性。目的是发现瓶颈、评估系统能力、优化性能和确保可靠性。在**双十一大促**等高并发场景下,性能测试至关重要。它有助于合理规划资源,降低成本,提升效率。测试工程师需掌握性能调优,理解压力曲线图,识别最佳并发用户数和最大承载点。通过测试,确保系统在最佳效率下运行,避免资源浪费和用户满意度下降。
|
SQL Java 数据库连接
MyBatis的逆向工程
MyBatis的逆向工程
225 0
|
数据可视化 Java 测试技术
软件测试——性能测试1
软件测试——性能测试
439 0