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

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

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

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

img_1b2beac6dd92ef63b900bd154a5d3c34.png

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

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

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

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

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

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

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

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

优秀的个人博客,低调大师

微信关注我们

原文链接:https://yq.aliyun.com/articles/652754

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
Mario,低调大师唯一一个Java游戏作品

Mario,低调大师唯一一个Java游戏作品

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS

Oracle Database,又名Oracle RDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的、适应高吞吐量的数据库方案。

Apache Tomcat7、8、9(Java Web服务器)

Apache Tomcat7、8、9(Java Web服务器)

Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。

Eclipse(集成开发环境)

Eclipse(集成开发环境)

Eclipse 是一个开放源代码的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括Java开发工具(Java Development Kit,JDK)。