`
frank1998819
  • 浏览: 751972 次
  • 性别: Icon_minigender_1
  • 来自: 南京
文章分类
社区版块
存档分类

电商前端交易型系统设计原则(转)

 
阅读更多

作者: http://jinnianshilongnian.iteye.com/blog/2312284

从毕业到现在已经快7年开发经验了,做过基础用户系统、积分商城、偷菜游戏、论坛、博客等等;也一个人全栈开发在线视频网站(http://sishuok.com/),也开发过几万、几十万、几千万、几个亿不同量级的系统,踩过不少坑,也学到许多经验。

 

设计了一些系统,也有了一些自己的观点,个人认为设计系统要因场景因时间而异,一个系统不是一下子就设计的非常完美,在有限的资源情况下一定是先解决当下最核心的问题,并预测/发现未来可能出现的问题,一步步解决最痛点的问题。也就是说系统设计是不断迭代的过程,在迭代中发现问题修复问题;即满足需求的系统是不断迭代优化出来的,不是一下子就架构的非常完美,这是一个持续的过程,个人不相信完美架构银弹。不过如果一开始就有好的基础系统设计,未来可以更容易达到一个比较满意的目标。

 

在设计系统时应该多思考墨菲定律

1、任何事都没有表面看起来那么简单;

2、所有的事都会比你预计的时间长;

3、会出错的事总会出错;

4、如果你担心某种情况发生,那么它就更有可能发生。

 

但是也要思考80/20法则,在系统设计初期将有限的资源用到刀刃上,我们的目标是系统满足现有需求并能支持未来需求。

 

在持续开发系统过程中前辈们也总结了很多设计原则/经验;而我个人也有幸运用了一些经验/原则。设计原则是系统发展初期或进化过程中根据自己系统特征匹配使用的,如果刚开始不是核心问题请不要复杂化系统设计。

 

拆分

在系统设计初期,是做一个大而全的系统还是进行按功能拆分系统这个需要进行权衡;比如做私塾在线时本身用户量/交易量不会特别大,而且开发就我一个人,资源有限,那就没必要对系统拆分(比如拆分商品、订单等等),就是做一个大而全的系统。而比如设计一个京东秒杀系统,预测到一旦上线量会非常大,而且投入的资源还是蛮充足的,这种情况下就要考虑进行按功能拆分系统。

 

笔者遇到的拆分主要有如下几种情况:

系统维度:按照系统功能/业务拆分,比如商品系统、购物车、结算、订单系统等等;

功能维度:对一个系统进行功能再拆分,比如优惠券系统,可以拆分为后台券创建系统、领券系统、用券系统等;

读写维度:根据读写比例特征进行拆分,比如商品系统,交易的各个系统都会读取,读大于写,因此就可以进行拆分:商品写服务、商品读服务;读服务可以考虑全量缓存提升性能;比如写的量太大,需要考虑分库分表;还有些聚合读取的场景,如商品详情页,请考虑数据异构拆分系统,将分散在多处的数据聚合到一处存储,提升读的性能和可靠性;

AOP维度:根据访问特征,按照AOP进行拆分,比如商品详情页,可以分为CDN、页面渲染系统;CDN就是一个AOP系统;

模块维度:比如按照基础或者代码维护特征进行拆分,如基础模块:分库分表、数据库连接池等等;还有如代码维护一般按照三层架构(Web、Service、DAO)进行划分。

 

服务化

首先判断是不是只需要简单的单点远程服务调用即可,如果单机扛不住了需要集群,是不是可以在客户端注册多台机器,使用Nginx进行负载均衡即可解决;如果随着调用方越来越多,就要考虑使用服务自动注册和发现(如Dubbo使用zookeeper);还要考虑服务的分组/隔离,比如有的系统访问量太大导致把整个服务打挂,因此需要为不同的调用方提供不同的服务分组,隔离访问;后期还会随着调用量的增加还要考虑如服务的限流、黑白名单等等。还有一些细节需要注意,如超时时间、重试机制、服务路由(能动态切换不同的分组)、故障补偿等等,这些都会影响到服务的质量。

 

总结为进程内服务--->单点远程服务--->集群手动注册服务--->自动注册和发现服务---->服务的分组/隔离/路由---->限流/黑白名单。

 

数据版本化,可回滚

在设计时考虑是否需要进行数据的版本化,数据维护出问题是否需要回滚。比如商品的维护是不是需要版本化。我们目前有一些非常重要的系统需要对数据进行版本化并且支持可回滚。整体设计类似于下图设计:


 

 

流程可定义

如果接触过保险业务,会发现不同的保险理赔服务是不一样的,因此我们在系统设计时就设计了一套理赔流程服务。而承保流程和理赔流程是分离,然后进行关联,从而可以复用一些理赔流程并提供个性化的理赔流程。

 

状态与状态机

在设计交易订单系统时,会存在正向状态(待付款、待发货、已发货、完成)和逆向状态(取消、退款)等,正向状态和逆向状态应该根据自己系统的特征来决定是不是需要分离存储。

 

另外还有订单状态的变迁,比如待支付、已支付待发货、待收货、完成的迁移;要考虑是不是需要使用状态机来驱动状态的变更和后续流程节点操作。

 

还要考虑并发状态修改问题,同时对同一个订单只存在一个修改;状态变更的有序问题,状态变更消息的先到后到问题,如支付成功消息和用户取消消息的时间差。

 

消息队列

消息队列,用来解耦一些不需要同步调用的服务或者订阅一些自己系统关心的变化;使用消息队列可以实现服务解耦(一对多消费)、异步、缓冲(削峰)等。比如电商系统中的交易订单数据,该数据有非常多的系统关心并订阅,比如订单生产系统、定期送系统、订单风控系统等等;如果订阅者太多,那么订阅单个消息队列就会成为瓶颈,此时需要考虑对消息队列进行多个镜像复制。

 

大流量缓冲持久化

在电商搞大促时,此时的系统流量会高于正常流量的几倍甚至几十倍,此时就要进行一些特殊的设计来保证系统平稳度过这段时期;而解决的手段很多,一般都是牺牲强一致性,而是保证最终一致性即可。

 

比如扣减库存,可以考虑这样设计:


 

直接在Redis中扣减,然后记录下扣减日志,通过Worker去同步到DB。

 

还有如交易订单系统,可以考虑这样设计:

 

首先结算服务调用订单接单服务将订单存储到:订单Redis和订单队列表,订单队列表可以按照需求水平扩展N个表,通过队列缓冲表提升接单的能力;然后通过同步Worker同步到订单中心表;假设用户支付了订单,订单状态机会驱动状态变更,此时可能订单队列表的订单还没有同步到订单中心表,此时状态机就要根据实际情况进行重试。

 

如果用户查看单个订单详情可以直接从订单Redis就能查到;但如果查询订单列表需要考虑订单Redis和列表的合并。

 

同步Worker在设计时需要考虑并发处理和重复处理的问题,单机串行扫描处理(每台Worker只扫描其中的一部分表)还是集群处理(Map-Reduce),另外需要考虑是否需要对订单队列表添加相关字段:处理人(哪个应用正在处理)和处理状态(正在处理、已处理、处理失败)。

 

数据校对

在使用了消息异步机制的场景下,可能存在消息的丢失,需要考虑进行数据校对和修正来保证数据一致性和完整性。可以通过Worker定期去扫描原始表进行补偿,扫描周期根据实际场景进行定义。

 

数据异构化

订单分库分表一般按照订单ID进行分,那么如果要查询某个用户的订单列表就需要聚合N个表的数据然后返回,这样会导致订单表的读性能很低;此时需要对订单表进行异构,异构一套用户订单表,按照用户ID进行分库分表;另外还需要考虑对历史订单数据进行归档处理。

还一种异构场景,如商品详情页,因为数据来源太多,影响服务稳定性的因素就太多了,因此最好的办法是把使用到的数据进行异构存储,形成数据闭环;提升服务的性能和稳定性。而有些数据异构的意义不大,如库存价格可以考虑异步加载,或者并发请求合并。

 

后台系统操作可反馈

在我接触过的很多系统,很多场景都需要反馈,比如修改了某些内容想预览看看最终效果,即想得到一些反馈;还有一些是规则系统,希望看到这些规则在系统数据下的反馈。因此在设计后台系统请考虑效果的可预览、可反馈。

 

后台系统审批化

对于有些重要的后台功能需要设计审批流,比如调整价格,并对操作进行日志记录从而保证操作可追溯、可审计。

 

防重设计

比如结算页需要考虑重复提交,还有如下单扣减库存时需要防止重复扣减库存。解决方案可以考虑防重KEY、防重表。而有些场景如重复支付,如有的电商网站同时支持微信支付、京东支付,渠道不一样是无法防止重复支付的,但是系统设计时需要将支付的每笔情况记录下。比如下图是我在京东使用京东支付和微信支付模拟的重复支付之后进行退款的支付明细:



 

 

幂等设计

在交易系统中经常会用到消息,而现有消息中间件基本不保证不发生重复消息的消费;因此需要业务系统考虑在重复消息消费时进行幂等处理。还有如使用第三方支付时,第三方支付会进行异步回调,因此也要考虑做好回调的幂等处理。

 

文档&注释

我接触的一些系统是完全没有文档、代码没有注释的,完全都是人传人;这将导致后来人接手很痛苦,而且对有些代码是完全不敢改动的,比如有些代码完全是因为业务的一些特殊情况而写的,可以说是没有注释是完全不懂为什么那么做的。因此在一个系统发展的一开始就应该有文档库(设计架构、设计思想、数据字典/业务流程、现有问题)、业务代码/特殊需求有注释。

 

备份

包括代码和人员。代码主要提交到代码仓库进行管理和备份,代码仓库应该至少具备多版本的功能。人员备份指的是一个系统至少应该有两名开发了解,即假设其中一名离职了也不会出现新人接手之后手忙脚乱事故频发的状况。还有一些是“核心人员”,写着系统的核心代码,被认为是“不可替代的”,这种情况也是尽可能的让他带一名兄弟一起开发核心代码(业务系统),即使离职也还是可以努力下克服困难的。

 

本文只是整理了一小部分原则,还有很多好的原则无法在一篇文章中全部阐述,比如可回滚(系统出问题时第一时间应该回滚处理,必要情况下摘除并保留一台问题机器进行问题排查)、有损服务(故障功能降级/屏蔽、部分人可用、部分系统可用)、灰度发布(功能只对部分人开发,从而保证假设出问题只是影响一小部分人)等等,每一个原则都可以写一篇文章好好阐述。

 

前端交易型系统本身是非常复杂的,以上原则只是笔者在实际开发时遇到过并使用的一些原则,而还有很多好的原则和经验是可以借鉴的,如果您有好的想法欢迎整理成文章分享给更多的人。另外笔者对支付/结算、供应链、库房生产等部分也不熟悉,只进行了前端交易系统的一些原则的总结,也希望更多人加入进来来完善设计原则库。

分享到:
评论

相关推荐

    MySQL_B2C.rar_b2c_b2c 前端_电商_电商 java_电商系统

    5. **电商系统设计**:一个完整的电商系统需要考虑多个方面,如用户认证与授权、商品分类与搜索、库存管理、支付集成(包括第三方支付平台)、物流跟踪、评价系统、促销策略等。此外,系统还需要有良好的安全性,...

    基于html和jquery的电商管理前端页面

    这样的系统设计易于扩展,可以添加更多的功能,如评论系统、促销活动、物流追踪等。同时,前端HTML和jQuery可以配合其他库(如Bootstrap或Vue.js)进一步提升界面美观度和交互体验,后端SpringBoot可以结合其他...

    django+mysql电商推荐系统

    虽然题目没有明确提到,但一个完整的电商系统通常需要前端界面展示推荐结果。这可能涉及到HTML、CSS、JavaScript,以及现代前端框架如React或Vue.js。 9. **性能优化**: 针对高并发场景,可能需要考虑缓存策略...

    .NET 开发 C#开发 书籍电商交易平台

    在开发电商交易平台时,C#的面向对象特性如类、接口、继承、多态等,将有助于设计清晰、可扩展的架构。例如,可以创建Book、Customer、Order等类来抽象实际业务对象,通过接口实现服务层和数据访问层的解耦。 在...

    基于java的ebuy电商项目系统设计与实现(源代码+部署视频).zip

    《基于Java的ebuy电商项目系统设计与实现》 在当今数字化时代,电子商务系统的开发与实施已经成为企业不可或缺的一部分。本文将深入探讨一个基于Java技术栈的ebuy电商项目,包括其设计原则、核心技术以及实现过程。...

    javaweb电商系统设计的开题报告.docx

    【JavaWeb电商系统设计】 JavaWeb技术在电商系统设计中扮演着重要的角色,尤其是在构建大型、复杂的电子商务平台时。本课题旨在设计并实现一个基于JavaWeb的仿淘宝购物网站系统,利用MVC(Model-View-Controller)...

    基于java-web电商系统设计的开题报告.docx

    《基于Java-Web电商系统设计的开题报告》 该开题报告主要探讨了基于Java Web技术设计电子商务平台——一个类似淘宝的购物网站系统。在当前互联网高速发展的背景下,电商平台已经成为人们生活的重要组成部分,尤其在...

    毕业论文-基于JSP的电商管理系统的设计与实现

    析 ................................................后续章节将详细探讨系统设计、系统实现、系统测试以及系统维护等方面,确保电商管理系统不仅满足功能需求,还具备良好的性能和安全性,为企业提供可靠的运营支撑。

    【Java毕业设计】使用 Go 语言实现电商交易系统,该系统聚集类似淘宝、京东、、当当、小米、携程等子系统。希望该项.zip

    【Java毕业设计】使用Go语言实现电商交易系统是一项复杂而具有挑战性的任务,涉及到多个关键领域的知识和技术。在这个项目中,开发者将面临构建一个类似淘宝、京东、当当、小米和携程等大型电商平台的集成系统。以下...

    基于MVC模式开发的B2B2C电商系统设计思路分析.pdf

    本文主要探讨了基于MVC(Model-View-Controller,模型-视图-控制器)模式开发的B2B2C(Business-to-Business-to-Consumer,企业对企业对消费者)电商系统的设计思路。B2B2C电商系统是一种新型的电商模式,它允许多个...

    HTML5:电商网站设计与实现.pdf

    在电商网站的设计与实现过程中,前端页面展示是至关重要的部分。HTML5利用其新增的语义标签,如、、等,能够更好地定义页面结构,从而提升页面的内容组织性和可访问性。通过CSS3和Bootstrap的配合使用,不仅能够实现...

    springboot241基于SpringBoot+Vue的电商应用系统的设计与实现.zip

    《基于SpringBoot+Vue的电商应用系统设计与实现》 在现代互联网技术的快速发展下,电商应用系统的构建已经成为企业数字化转型的重要一环。本项目"springboot241"采用主流的技术栈——SpringBoot和Vue.js,旨在打造...

    html+css+bootstrap实现电商,农业产品交易农业电商 Chashi 前端素材 .zip

    Responsiveness:后台管理系统应当是响应式设计,能够适配不同设备屏幕大小,包括电脑、平板和手机等。 权限控制:根据用户角色设定不同的权限,确保用户只能访问其权限范围内的功能。 数据安全:对用户数据进行加密...

    myE-commerce项目是一套电商系统,包括前台电商子系统及后台管理子系统.zip

    此外,前端与后端通过API进行通信,这通常涉及到JSON格式的数据交换,以及RESTful API的设计原则。 后端则是系统的“大脑”,负责处理业务逻辑、数据库操作、用户验证以及与第三方服务的集成。myE-commerce的后端...

    javaweb整合开发:电子商务系统源码

    在JavaWeb领域,整合开发是实现复杂业务应用的关键步骤,特别是在构建像电子商务系统这样的大型项目时。本资源“javaweb整合开发:电子商务系统源码”提供了一个完整的电子商城系统的实例,旨在帮助开发者深入理解...

    PHP电商网站源码PHP电商网站源码

    - MySQL:常见的关系型数据库,存储网站的各种数据。 - MVC(Model-View-Controller)模式:源码可能采用了MVC架构,分离业务逻辑、数据模型和用户界面,提高代码可读性和可维护性。 - 框架:可能会使用Laravel、...

    关于电商项目的

    在电商项目开发中,涉及到的技术领域广泛且深入,包括前端界面设计、后端服务构建、数据库管理、版本控制以及用户体验优化等。以下是一些关键的知识点: 1. **Git**:Git是分布式版本控制系统,对于电商项目的开发...

    KgMall一款电商系统

    数据库优化是电商系统性能的关键,包括合理的数据模型设计、索引优化以及读写分离、分库分表等策略。 KgMall的前端部分可能使用React或Vue.js等现代JavaScript框架,提供流畅的用户体验和高效的页面渲染。同时,...

    Java通用型支付+电商平台双系统实战

    3. **系统设计**:完成整体架构设计和模块划分。 4. **编码实现**:按照设计文档进行开发。 5. **单元测试与集成测试**:确保每个模块的功能正确,并进行系统联调。 6. **部署上线**:将系统部署到生产环境。 7. **...

    电商项目实战讲解视频80~81

    2. **系统架构设计**:电商系统通常包含前端展示、用户管理、商品管理、订单处理、支付接口、库存控制等多个模块。80~81集可能讲解了如何设计高可用、可扩展的架构,以应对大流量和高并发的挑战。 3. **数据库设计*...

Global site tag (gtag.js) - Google Analytics