百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 运营笔记 > 正文

淘宝万亿级海量交易订单存储在哪?

ann3311 2024-12-22 14:19 16 浏览 0 评论

01淘宝交易订单系统介绍

天猫和淘宝每天发生的实物和虚拟商品的交易达到亿级别。考虑到一次成功交易的整个链路,会涉及到会员信息验证,商品库信息查询,订单创建,库存扣减,优惠扣减,订单支付,物流信息更新,确认支付等。

链路中的每一环都涉及到数据库中记录的创建和状态的更新,一次成功的交易可能对应到后台信息系统上数百次数据库事务操作,支撑交易系统的整个数据库集群则会承担每日高达数百亿的事务读写。这除了给数据库系统带来巨大的性能挑战之外,每日递增的海量数据也带来巨大的存储成本压力。

交易订单作为其中最为关键的信息,由于可能涉及交易纠纷处理,需要随时提供用户查询,必须永久的记录在数据库中。淘宝成立至今近17年,所有与订单相关的数据库记录总量达到了万亿级别,其所占用的磁盘空间也早已超过PB级。

在一个这样大体量的数据集上,需要能够满足用户随时查询的低延时需求,同时需要达到极低的存储成本,在技术上是一个非常大的挑战。


用户的历史订单记录数据量巨大且不能丢失

02淘宝交易订单库的架构演进历史

淘宝从2003年成立至今近17年的时间,随着流量不断上涨,交易订单数据库的架构也经历过数次演进。

第一阶段,开始由于流量较小,使用了一套Oracle数据存储了所有的订单信息,新订单创建和历史订单查询都在同一套数据库进行。

第二阶段,由于历史订单量数据量越来越大,单一一套库已经不能满足同时满足性能和容量的问题,于是对交易订单库进行了拆分,单独建立了一个Oracle历史库,将三个月以前的订单迁移进历史库,同时由于数据量巨大,查询性能不能满足需求,因此当时的历史订单不提供查询功能。用户只能查询三个月之内的订单信息。

第三个阶段,为了解决扩展性和存储成本问题,交易历史库整体迁移到了HBase方案,这套方案在当时很好了解决了存储成本和业务查询需求这2个诉求。整体方案是使用主表结合索引表,查询订单详细信息通过主表完成,通过买家或者卖家ID查询订单,则需要借助索引表先得到订单号。

但这个方案遗留一个问题:订单并不是严格按照90天进行迁移的,有很多类型的订单并不迁移到历史库,导致已买到--订单列表的排序是乱序的,已买到的订单列表不是严格按照时间由近到远排序的,用户如果按照订单列表一页一页往下翻,会发现自己最近的订单”突然丢了”(实际上没有丢的,只是乱序了,再往后翻就有了)。

第四个阶段,历史库采用基于X-Engine引擎的PolarDB-X集群,在满足存储成本的同事,提供与在线库一样的索引能力,解决乱序问题。

03淘宝交易订单库的业务痛点

回顾淘宝交易库的演进历史,自拆分出独立的交易历史库之后,在持续十年时间里,业务团队和数据库团队一直在应对几个核心的挑战:

  • 存储成本,每日写入量巨大且数据永不删除,必须要保证极低的成本。
  • 节省存储成本的前提下,保证丰富的查询特性,例如按时间维度排序等。因此底层数据库需要支持二级索引,且二级索引需要保证一致性和性能。
  • 保证较低的查询延时,不影响用户使用体验。虽然90天前的历史订单的查询量比90天内要少很多,但这依然是直接面对用户的,需要保证长尾延时在一定限度内。

在2018年,因为数据库存储的原因导致的订单排序错乱的问题,受到越来越多的投诉,给用户带来非常大的困扰,业务上决定根治这个问题。从前面的分析总结看,理想中的交易历史库方案需要同时满足三个条件: 低成本,低延时,特性丰富。使用和在线库一样的InnoDB引擎则满足不了存储成本的要求,而使用HBase则满足不了一致性二级索引等要求。

04基于X-Engine引擎的历史库方案

2018年,阿里自研的X-Engine引擎逐步在集团内部落地,其针对阿里巴巴交易业务的流水型特征设计了原生的冷热分离的架构,X-Engine引擎中的冷数据记录在数据页中紧凑排列并默认对所有数据块进行压缩,这套架构兼顾了性能和成本,很快在内部非常多的业务中落地,例如:X-Engine如何支撑钉钉数据量激增。

在考察交易历史库的方案时,一个思路是合并在线库和历史库,依赖X-Engine自身的冷热分离能力, 实现对90天内交易订单的高性能访问和90天以前交易订单记录的低成本存储。同时一套统一的交易订单库,可以提供诸如二级索引等功能,用户订单不能按时间排序的问题也随之解决,业务层的代码将非常简单

但交易订单系统在在线库/历史库分离的架构下迭代了十年的时间,很多业务系统的代码对这套分离架构做了兼容,考虑到对业务代码改造以及迁移的风险,我们在初期继承了之前在线和历史分离的架构。只是将原有的HBase集群替换成了PolarDB-X集群(基于X-Engine引擎的版本):

  • 在线库依然沿用之前的MySQL InnoDB集群,但是只保存90天的数据量,90天之前的订单会被删除,数据量少,可以保证较高的缓存命中率,确保读写延时。
  • 通过数据同步将在线库中超过90天的订单迁移到历史库中,迁移之后该部分订单从在线库删除。
  • 历史库切换为X-Engine,保存全量的交易订单数据,90之前的订单读写,直接操作历史库, 同时历史库承接在线库的所有迁移写入负载。

这套架构上线之后,交易历史库的存储成本相比较于使用HBase没有上升,同时由于历史库和在线库能力相同,可以创建完全一样的索引,历史订单恢复了对订单按时间排序功能的支持,同时其读取延时也得到了保证。

05数据库架构参考

在淘宝交易历史库的方案中,考虑到业务层面历史代码架构的延续性,采用了InnoDB引擎在线库和X-Engine历史库分离的方案。在这套架构中,X-Engine历史库其实同时承担了在线库迁移过来的写入以及90天以前记录的读写流量。

实际上,考虑到淘宝交易订单记录流水型的访问特征(最近写入的记录会被大量访问,随着时间推移,记录访问频次急剧衰减),X-Engine引擎内部的冷热分离机制就能很好的处理这种流水型业务,所以单一X-Engine数据库集群完全解决需求

对于新开业务或者有大量流水型记录存储需求的现有业务且业务层面还未做冷热分离,我们建议直接使用一套X-Engine引擎,在存储成本降低的同时,DB层的访问代码会更简单。基于X-Engine引擎的PolarDB-X分布式数据库可以同时解决scale out问题和成本问题。

目前X-Engine引擎已经上线阿里云, 经过阿里内部业务验证,欢迎有成本和性能需求的用户购买使用。详情点击「阅读原文」

相关推荐

双11大考,淘宝女装神店如何打败ONLY和VERO MODA?

文/天下网商记者孙姗姗除了聚光灯下的优衣库、韩都衣舍、拉夏贝尔等天猫大卖家,双11的女装赢家还有淘宝女装神店们。瑞丽当家模特张大奕的淘宝店铺就出现粉丝疯抢的画面;在2013年10月底被骆驼高价收购,...

宁夏残疾人电商平台迎来首单团购

宁夏残疾人电商平台团购首单签约仪式现场。李佩珊摄中新网银川6月24日电(于翔李佩珊)6月24日,宁夏兴电工程监理有限责任公司在宁夏残疾人电商平台签约团购价值63000元(人民币,下同)的300...

淘宝卖家自曝团购化妆品内幕,真惊悚!

青眼/花椒小紫最近对某品牌化妆品特别着迷,一直找不到靠谱的网店买。一天中午午休时,她的网页上突然就跳出来了某产品的信息,她连忙打开进去看,页面的销量和价格让她十分心动。刚开始她觉得团购价比专柜价就便宜...

日照绿茶首次出击“聚划算”

本报日照讯7月22日,日照绿茶首个“聚划算”团购活动在淘宝电商平台正式开始,一直在日照茶界担当领头羊的圣谷山再次成为第一个“吃螃蟹的”日照茶品牌。本次团购开锣仅十分钟,就收获订单300多份,充分显示...

关于上投摩根智慧生活灵活配置混合型证券投资基金在淘宝官方店铺实施费率优惠的公告

来源一、活动时间2016年3月14日至2016年4月8日(注:若活动期间,智慧生活基金募集时间发生变化,则本次费率优惠时间也相应调整)二、适用基金上投摩根智慧生活灵活配置混合型证券投资基金(基金代...

网店出售0.5元“怒骂苏家三父子”,一周300多人来撒气

#苏明成出来挨打#、#苏大强又作妖#、#苏家三个男人都是自私自利#……自从电视剧《都挺好》热播以来,热搜天天都被剧中的苏家三父子“花式霸屏”,下面则是网友一水地怒骂。演员郭京飞继带头“打倒”自己的角色...

淘宝内测深色模式:iOS领先一步

上方文Q微信最近正在内测黑暗模式,而手机淘宝也在内测自己的深色模式,这下晚上剁手更方便了。其实,很多APP都已经支持“黑夜模式”,但深色模式或者黑暗模式并不是简单地把APP界面变成深颜色。深色模...

接地气春联大比拼!音符代码元素周期表齐上阵,万物皆可写春联

"爆竹声中一岁除,春风送暖入屠苏。千门万户瞳瞳日,总把新桃换旧符。"春节贴春联,这是宋朝开始就有的习俗,而发展到如今的90、95后手里,春联有了更多新鲜玩法!最明显的变化就是,90后入...

标品的破局之道:2025年淘宝新规下的实战思路与策略

**一、现状分析:标品困境的底层逻辑**近年来,标品赛道的竞争已进入白热化阶段。同质化严重、价格战激烈、流量成本飙升,传统“抢关键词+刷单冲排名”的模式逐渐失效。究其原因,**淘宝2025年算法的核...

iPhone通知中心神器Launcher代码大全

前段时间发过两篇关于iPhone通知中心神器Launcher的使用方法和技巧,期间也有很多感兴趣的朋友在微信后台询问一些应用程序的代码,这两天抽空整理了一下,今天就给需要的朋友们发出来,感兴趣的朋友可...

成人用品淘宝店怎么开?需要哪些条件?

现在在网上购买情趣用品已经成为一种趋势,这反映了国人在性方面的开放和进步。然而,由于国人的性格偏向于含蓄内敛,去实体店购买这类商品可能会让人感到不自在。因此,网购成为了解决这个问题的途径之一。但是,需...

从零开始做电商

不少人想做副业,都是从摆摊、自媒体之类开始,也有人选择在京东、淘宝上开个店铺做电商。但电商并不是直接注册账号就可以的,有许多东西,我们都需要提前了解。电商是一个行业,与其说是一个行业不如说是一项技能,...

这年头买个东西,为什么我们都不能给差评了?

购物、打车、吃饭、叫外卖……现在可以在网上写评价的机会越来越多,也有更多的人会来叫你“亲”,然而如果给了差评那你的待遇就不好讲了。记得去年在网上买了睡衣结果穿了一周毛绒掉了一地。于是给了差评并上传图片...

动销是什么意思?

如果是刚做店的朋友,应该经常能从各个博主那边听到动销这个词,那么动销到底是什么,有什么用?该怎么做?我们今天呢就来讲一下这个问题。动销其实就是人为的让你的产品产生销量,直白一点就是S单。不管是有货源的...

货还未发,退款先行,这样的满减活动值得鼓励吗?

双十一的狂欢购物节虽然已经落下了帷幕,但后续的一些操作才刚刚开始。每年的双十一各大卖家都会想出各种各样的方法来刺激消费者消费,比如跨店满减、店铺消费券、预付款等等,商家们想尽办法规则弄复杂一点,只要有...

取消回复欢迎 发表评论: