电商商品详情页演进历程

本贴最后更新于 2345 天前,其中的信息可能已经天翻地覆

今天给大家分享下电商商品详情页演进过程。在电商系统中,电商详情页是最重要的一个模块。接下来给大家讲从小型电商商品详情页到大型电商商品详情页的整体设计思路。以图文结合的形式给大家进行讲解。

第一版的电商详情页的设计比较简单,看下图
663e5e23e1094fa6b1d7ec2cbcd9c7a5.png

一台 nginx+ 电商 web 应用 + 数据库
用户访问我们的页面,请求先到 nginx 上,nginx 把请求分发到电商 web 应用,电商 web 应用到数据库获取用户请求的数据,电商 web 应用返回 html 给用户。随着业务的推广,用户量越来越大,整体服务开始扛不住了,你开始加电商 web 应用,但是成本有限,你不可能无限的加机器,还有数据库的压力变动非常大,那么就需要进行系统优化。

这时候,我们需要对系统进行重构。重构的思路是访问静态页面速度会快很多,数据库的压力也会减少。
977bbd7693914f56be49a4739d961945.png

如上图所示,会有几个系统来完成这个事情,1、数据监听服务;2、渲染 html 模板服务;

数据监听服务作用:实时的监听数据库商品数据的变化。(ps:当然也可以手动触发商品 html 的生成,只是每次都需要人工处理)
渲染 html 模板服务:这里保存着商品详情页的模板,只要将相应的数据填充到 html 模板里面,就生成 html 文件,然后把这些 html 文件上传到 nginx 服务器上面。
nginx 服务器:该服务器里面保存着商品详情页的 html 文件,用户访问某个页面的时候,直接把 html 返回给用户。

这样数据库的压力就小很多了,web 服务器的压力也小很多,压力都在 nginx 上,html 是在 nginx 机器上,没有机器之前的 io,响应速度也是很快的。但是这个方案也是有缺点的,最大的缺点就是,如果你有上亿商品的时候,商品模板变了,这时你生成商品 html 代码就要好久好久,还有时效性也会变差。这套方案适合小型电商商品详情页,你的商品没那么多,如果你能忍受时效性差,那你可以使用。这时候我们又要对系统进行重构了。

重构后的系统设计包括以下几个模块
7a887932b84a41cf9cb7572be4983126.png

简单说明下几个系统要做的事情:
nginx 服务:保存着 html 模板和商品本地数据。
redis:保存着商品的数据。
缓存数据服务:把数据保存到 redis 和 ehcache 里面,同时监听 MQ,商品数据有变动马上就知道,然后调用商品服务。
商品服务:从数据库获取商品信息,并通知 MQ。
MQ:消息队列,商品有变动通知订阅者。

以下是时序图:
91fcaac6aca542d88a215b92cfcd0961.png
上图是整个流程跳转,看图比用文字描述要清晰的多

这个方案,可以抗住上亿的流程,如果你的模板改了,只要在 nginx 上面修改掉模板,用户就可以马上看到了。使用了多级缓存,在高并发上也没有任何问题。
这个方案的缺点是,数据具有一点的延迟性,因为 nginx 本地缓存有一个失效时间。但是商品详情页绝大多数的数据的实时性不是那么高。如果实时性要求很高的话,就不要在 nginx 上做数据缓存,直接从 redis 上面取,redis 上的数据是实时更新的。一个商品详情页中必须要实时展示的数据是很少的。

那么到这里,电商商品详情页的系统已经介绍完了。这里在说下,系统是随着你的业务慢慢演进的,就像 taobao,jd 他们也是从小系统慢慢演变成大系统。你可以结合自己现在所处的阶段,对比着看以上方案,希望能给你带来帮助。如果有写的不对的地方,请指正。

  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3455 回帖 • 164 关注
  • 电商
    6 引用 • 41 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
chaigx
欢迎关注我的公众号:程序之声。有些文章没办法同步过来,访问个人博客:http://www.chaiguanxin.com

推荐标签 标签

  • 尊园地产

    昆明尊园房地产经纪有限公司,即:Kunming Zunyuan Property Agency Company Limited(简称“尊园地产”)于 2007 年 6 月开始筹备,2007 年 8 月 18 日正式成立,注册资本 200 万元,公司性质为股份经纪有限公司,主营业务为:代租、代售、代办产权过户、办理银行按揭、担保、抵押、评估等。

    1 引用 • 22 回帖 • 786 关注
  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    1 引用 • 28 回帖 • 2 关注
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    70 引用 • 193 回帖 • 412 关注
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    108 引用 • 295 回帖
  • FlowUs

    FlowUs.息流 个人及团队的新一代生产力工具。

    让复杂的信息管理更轻松、自由、充满创意。

    1 引用 • 2 关注
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖 • 1 关注
  • 安全

    安全永远都不是一个小问题。

    203 引用 • 818 回帖 • 1 关注
  • 博客

    记录并分享人生的经历。

    273 引用 • 2388 回帖
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 570 关注
  • 程序员

    程序员是从事程序开发、程序维护的专业人员。

    588 引用 • 3538 回帖
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖 • 3 关注
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    54 引用 • 37 回帖
  • 运维

    互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。

    151 引用 • 257 回帖
  • 旅游

    希望你我能在旅途中找到人生的下一站。

    95 引用 • 901 回帖
  • Access
    1 引用 • 3 回帖 • 2 关注
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖 • 1 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 643 关注
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    57 引用 • 25 回帖 • 2 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 19 关注
  • RabbitMQ

    RabbitMQ 是一个开源的 AMQP 实现,服务器端用 Erlang 语言编写,支持多种语言客户端,如:Python、Ruby、.NET、Java、C、PHP、ActionScript 等。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。

    49 引用 • 60 回帖 • 342 关注
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖 • 7 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    187 引用 • 318 回帖 • 256 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    71 引用 • 535 回帖 • 826 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    42 引用 • 130 回帖 • 250 关注
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    91 引用 • 384 回帖
  • Angular

    AngularAngularJS 的新版本。

    26 引用 • 66 回帖 • 545 关注
  • NetBeans

    NetBeans 是一个始于 1997 年的 Xelfi 计划,本身是捷克布拉格查理大学的数学及物理学院的学生计划。此计划延伸而成立了一家公司进而发展这个商用版本的 NetBeans IDE,直到 1999 年 Sun 买下此公司。Sun 于次年(2000 年)六月将 NetBeans IDE 开源,直到现在 NetBeans 的社群依然持续增长。

    78 引用 • 102 回帖 • 702 关注