写点什么

支付宝背后的 OceanBase:国产自研分布式数据库这十年

  • 2019-04-17
  • 本文字数:6807 字

    阅读完需:约 22 分钟

支付宝背后的OceanBase:国产自研分布式数据库这十年

如果大家当时能看见原来十年后 OceanBase 能长成这样,可能十年前 OceanBase 得到的支持会好很多。但是这种如果是不存在的,很多时候你要先证明自己。


00:00 / 00:00
    1.0x
    • 3.0x
    • 2.5x
    • 2.0x
    • 1.5x
    • 1.25x
    • 1.0x
    • 0.75x
    • 0.5x
    网页全屏
    全屏
    00:00


    根据工信部数据显示,1998 年,中国软件企业 5000 家,市场规模 325 亿;到了 2018 年底,中国软件企业 3.78 万家,收入规模超过 6.3 万亿元,营收增长了 193.8 倍。可在最核心的基础设施三大件芯片、操作系统和数据库上,过去我们并未取得商用意义上的重大突破。


    不过,相比芯片和操作系统,国内数据库领域的局面要略微乐观一些。除了传统的数据库厂商、数据服务商,互联网巨头、云计算厂商、硬件厂商、新兴的创业公司也越来越多地投入到数据库的研发中。而谈及国产自研数据库,就不得不提 OceanBase。OceanBase 是完全由阿里巴巴和蚂蚁金服自主研发、全球首个应用于金融核心业务的分布式关系数据库。OceanBase 的研发始于 2010 年 6 月,因为选择从零开始,研发之路从一开始就磨难重重,中途因为找不到愿意使用的业务,团队曾经濒临解散。


    最终 OceanBase 还是跨越了死亡之谷,在蚂蚁金服实现了全面替代 Oracle,成功支撑了过去 5 年“双 11”蚂蚁金服全部核心业务的重压,创造了 25.6 万笔 / 秒支付峰值和 4200 万笔 / 秒请求数处理峰值这一业内全新的纪录。自 2017 年开始,OceanBase 开始走向外部商用,目前已经在数十家商业银行落地,其中包括南京银行、浙商银行、苏州银行、人保健康险等。OceanBase 帮助南京银行共同打造“鑫云 +”互金开放平台,实现贷款交易处理能力 10 倍提升,轻资产模式显著降低成本,从原有的 30~50 元 / 账户降低到上线后的 4 元 / 账户。日处理百万笔放款,平均处理时间小于 1 秒,让老百姓借钱更方便,真正实现了普惠金融。


    站在现在这个时间点上顾盼今昔,蚂蚁金服高级研究员、OceanBase 创始人阳振坤认为,OceanBase 的成功其实有行业和时代的必然性。

    时机

    2009 年开始,大量新的非关系型数据库如雨后春笋般涌出,在整个数据库行业掀起了一场空前盛大的 NoSQL 革命,如今赫赫有名的 Redis、MongoDB 皆诞生于那一年。NoSQL 的拥护者们积极提倡使用非关系型的数据存储,从而获得丰富而随需应变的可伸缩性。这时候的关系数据库早已过了而立之年,在此期间虽然曾短暂爆发过一些所谓终结关系数据库的革命,但最终都失败了,丝毫没有动摇到关系数据库的主导地位。


    但这一次似乎与以往不同,火热发展的云计算带来了对更大规模数据库的需求,而关系数据库的缺点则相应地被越来越多人诟病:不能够扩展、容量小、处理能力不够、成本又非常高。在当时的很多人看来,关系数据库的末日是真的要来了。2010 年,NoSQL 革命愈演愈烈,有行业专家发文直指“云计算时代属于 NoSQL,关系数据库已经日薄西山”。


    那时阳振坤已经在百度做了两年多的自研分布式系统。百度数以万亿计的网页意味着与日俱增的天量数据,阳振坤十分看好云计算系统的发展机会。同一年,阳振坤离开百度,加入阿里巴巴,就在上面这篇文章发出的 2 个月之后,开始了分布式关系数据库 OceanBase 的研发。



    数据库从诞生起已经有几十年的时间了,但基本上它的市场格局就没有多少变化,最早起来的几家厂商今天还是占据着统治地位。因为数据库非常难被替换,它处在整个产品或者产业链最底层的位置,替换风险很大,但收益相比起来却小得多。这也是为什么像 IBM、微软这样的后来者也无法取代 Oracle。这就导致了数据库变成了一个门槛极高、强者恒强的领域,后来者很难居上。前有 Oracle 挡道、后有 NoSQL 数据库追赶,在大部分人看来,那时候怎么也不会是自研关系数据库的好时机,但阳振坤却不这么想。


    加入阿里之后,阳振坤发现无论对淘宝还是支付宝,关系数据库都扮演着十分关键的角色,在使用上根本不可能摆脱。但已有的数据库,无论是商业数据库还是开源数据库,都有非常多的局限,远远无法满足如淘宝、支付宝这样的互联网和金融业务对高扩展、高并发、高可用和低成本的需求。单机数据库已经走到了尽头,下一步只能走向分布式,而分布式恰好是阳振坤所擅长的。如果能将分布式技术揉到数据库里面,解决单机数据库存在的各种问题,对当时整个互联网的基础设施都会是一个巨大的帮助和进步。阳振坤认为他们赶上了一个“天时地利人和”的好机会。


    “天时”指的是互联网的爆发式增长对数据库的高并发、大数据量提出了很大的需求,有了需求去推动就会容易得多;“地利”指的是阿里内部从淘宝到蚂蚁金服拥有大量需要使用数据库的场景,OceanBase 可以从不是特别重要的应用场景开始尝试,一步步地将数据库做成关键系统;“人和”指的是当时单机数据库已经走到了尽头,下一步一定是走向分布式,而当时团队成员大多是研究分布式出身,做的就是自己最擅长的工作。用阳振坤的原话就是:“这是千载难逢的机会,我们一定要做,而且一定能做成。”

    选择

    “其实绝大部分人都非常聪明,或者说智慧都足够,但最终能把事情做成的人却不多。有时候大家在想这个人是大聪明那个人是小聪明,不是说他的智慧不够。如果一个人把他的智慧放在做应该做的事情、需要做的事情、重要的事情上,可能这个人真的就是大聪明。”


    “一个不断破格的人”,这是早前某次采访中记者对阳振坤的评价。1984 年阳振坤考入北京大学数学系,硕士师从本系的张恭庆院士,后又转向计算机领域,博士师从计算机系的王选院士。需要强调的是,他修完大学课程只用了 3 年,硕士只用了一年多,成为王选院士博士生的时候他只有 24 岁。1995 年其所在团队研究成果获国家科技进步一等奖(排名第四),1997 年也就是他 32 岁那年被破格晋升为教授。


    在他人或许都安于现状之时,他却毅然选择了离校。个中原因也不复杂,他的工作更偏于工程,而在工业界有更多的机会,也能发挥更大的作用。2002 年离开北大 / 方正的时候,阳振坤内心很清楚自己必须要做点不一样的事情。他先是加入联想研究院担任首席研究员,负责无线通信领域的研究;后来接触到分布式系统并看好其前景,在微软亚洲研究院、百度所从事的工作都属于分布式这个范畴,前者侧重研究,后者偏重工程实践。


    回想在北大的那些年,阳振坤觉得特别感激的是,学数学让他有了一个很好的数学基础,后来转到计算机系以后,碰到了王选老师,又打下了一个比较牢靠的计算机基础,这才有了他后来的今天。作为对阳振坤影响最大的人,恩师王选有两点让他至今受益:一是如何判断一件事情是否有价值,二是“顶天立地”的技术理念,“顶天”就是技术上要不断追求新突破,“立地”就是要把技术做成通用产品,让整个社会都能普遍使用。


    其实 2010 年去淘宝的时候,阳振坤根本不知道自己会做什么事情。加入淘宝之后,摆在他面前的有两个选择,一个是加入正在快速发展的淘宝业务团队,去主管技术,这是一条已经能看到很大的发展机会、相对轻松的道路;另一条是阳振坤后来自己选的,从头组建团队做一个技术平台,也就是今天我们看到的 OceanBase 数据库。从加入淘宝到选择做自研数据库,一共只花了两个星期的时间。



    这不是一个容易的选择,但阳振坤相信自己的判断:“2010 年选这个项目的时候,我是觉得这件事情需要做。当时互联网迅速发展带来了对大数据量、高并发的需求,大家对传统单机数据库有很大的抱怨,觉得它既没有扩展能力,又没有高并发的能力,成本还非常高,但是互联网根本就离不开关系数据库。这件事情怎么看都是一件应该要做、需要做的事情。”阳振坤没有说出来的是,这件事到底有多难。


    那时候阿里巴巴刚开始要“去 IOE”,几乎没人想着说要自己从头做一个数据库。传统关系数据库都是通过外部硬件来保证可用性,用便宜的 PC 机替换高端服务器之后,硬件更容易出故障了,如何保证数据库高可用?高可用和数据一致性如何同时保证?分布式系统怎么同时实现 CAP 的要求?几十年来这么多做数据库的厂商,国内国外基本没有人成功过。而且从公司的业务发展的角度,也不可能等你几年把数据库做出来,再去发展业务,更可行的做法是基于开源做出一些东西,让业务先往前走。因此 OceanBase 立项之初,除了阳振坤和他当时的直属领导,其他人对这个项目要么不关心,要么不赞成。从零开始自研分布式关系数据库并全面替换 Oracle,在当时有多少人会相信这真的能做成呢?当时整个淘宝一共只有两三千人,而 Oracle 有十几万人,就算整个淘宝的人全部去做数据库,跟 Oracle 比起来也只是很小很小的一个比例。


    在阳振坤看来,如果一件事情几乎所有的人都认为它很重要、需要做,这件事情就已经不是创新了。当所有人都认为这件事情要做的时候,其实做这件事情的时机已经过去了一大半。作为最底层的基础软件设施,数据库需要很长时间的积累,不可能今年做,明年就能真正大规模地用起来。 虽然在 2010 年选择做数据库的时候,没有太多人看重和支持,对于团队来说这可能反而是一件好事。无人关注,反倒给了团队几年积累发展的时间。


    阳振坤不只要自研,还要把 OceanBase 定位成恩师王选所说的“顶天立地”的技术产品——走标准化的路,做一个通用的关系数据库产品,而不是一个仅仅在公司内部使用的产品。每个公司使用任何产品其实都只用了其中很小的一部分功能,如果只做满足公司自用需求的数据库,可能只需要投入十分之一、五分之一的人力物力时间。而要做成通用产品就意味着必须实现所有功能,这要困难得多,团队的投入、花费的精力和时间也要大好多倍。但也因为阳振坤最初的坚持,今天的 OceanBase 才得以走出蚂蚁金服,走进多家银行系统。不过这都是后话了。

    蛰伏

    “如果找不到愿意使用的业务,数据库系统是做不下去的。”


    OceanBase 的第一个客户来自淘宝收藏夹。当时的淘宝收藏夹正处于业务高速发展期,数据库的访问量飞快增长,面临着第二年服务器数量需要翻一倍甚至几倍的局面。业务方忙于寻找解决方案的时候,阳振坤主动找上门去提出了可以用 OceanBase 帮他们解决问题,把服务器数量降低一个数量级。四个月出 Demo,八个月出试用版,一年后系统正式上线,淘宝收藏夹就这样成了第一个吃 OceanBase 螃蟹的业务,新数据库取得了非常好的效果。这时候是 2011 年,收藏夹项目成为了 OceanBase 第一个小小的里程碑。


    但在后续一年多的时间里,OceanBase 团队一直在寻找更多业务,也确实有一些业务用了,却再也没有找到像淘宝收藏夹效果这么显著的业务。做数据库难度大、周期长,前几年的投入也许有那么一点点产出,但其实跟投入比几乎微不足道,团队面临的压力可想而知。数据库少不了人力投入,OceanBase 团队从最早只有阳振坤一个人,后来发展到 2012 年已经有 30 多个人了。占了这么多人头,但在公司里却没有足够多、足够重要的业务,没能产生足够大的价值和效益。团队陷入了一个比较困难的时期,甚至数度濒临解散。



    当被问及“中间有没有想过这事如果没做成,怎么办?”,阳振坤回答得云淡风轻:“不是每件事都能做成,那太难了。如果每件事在做之前都想着它能不能做成,那最后做成的事就会很少。”


    做数据库就像在黑暗中前行,守得住寂寞、担得了压力,甚至要有近乎偏执的性格才可能跨越死亡之谷,到达最终目的地。阳振坤团队中一位新人曾经向他表达过自己的困惑,当时这位新人入职三个月了,因为有太多东西要学,什么也没做出来,而跟他同时入职天猫的新员工才来了一个月,做的系统就已经在线上使用了。阳振坤当时给新人讲了一个故事,他说:“你过三年再看,没有人还记得那个同学三年前在天猫上把网页做了什么改版,可是三年以后你今天做的东西还会在生产系统中使用。”

    破茧

    在最困难也最危险的时候,团队迎来了一丝转机。2012 年底,公司把 OceanBase 整个团队调到了支付宝。支付宝属于金融领域,面临的数据库挑战会比其他业务更大,这相当于给了 OceanBase 团队一次从头开始的机会。


    2013 年夏天,支付宝也开始启动“去 IOE”,并希望能够把 Oracle 数据库替换掉。阳振坤又一次主动出击,向当时的主管、也是现在蚂蚁金服的 CTO 程立自荐了 OceanBase 的解决方案。


    金融行业数据库,最怕的就是突发故障导致数据丢失,涉及到钱的事,多了少了都是不可接受的。为了解决高可用与主备库数据一致的矛盾,OceanBase 将可用性做到了数据库系统内部,用一主两备或一主多备代替一主一备。主库到备库同步的时候不要求同步到每个备库,而是同步到包括主库在内的多数库(超过半数),也就是说总共三个库中如果有两个成功了,这个事务就成功了。如果任何一台机器出了问题,这个系统的可用性和数据一致性都是可以保证的。


    程立认可了阳振坤提出的方案,OceanBase 团队开始埋头开发,第一个要攻克的目标是支付宝交易库。2014 年双 11,OceanBase 迎来了第一次大考。



    大促开始前的凌晨,各个团队都在自己的作战室里热火朝天地准备。当时任蚂蚁金服董事长的彭蕾去了 OceanBase 团队的作战室,问大家:“有没有信心?”阳振坤跟彭蕾开了个玩笑说:“你看我们窗子都已经打开了,如果等会出问题,我们就准备从这跳下去。”


    在一开始的计划里,双 11 交易流量的 1% 会切给 OceanBase,但因为当时的 Oracle 数据库系统支撑不了汹涌而来的巨大流量,最后 OceanBase 成功支撑了 2014 年双 11 10% 的交易流量。经过了双 11 的考验之后,OceanBase 得到了更多的认可和支持。后来 OceanBase 团队获得了 2015 年蚂蚁金服的 CEO 大奖,这也是第一次由技术团队拿到这个奖。彭蕾希望借这个奖鼓励那些能够沉下心来、扎扎实实地把一项技术做好做扎实的技术人们。



    2015 年春夏,支付宝交易库和支付库都换成了 OceanBase;2016 年,支付宝账务系统上线,这也标记着 OceanBase 真正在金融系统最核心最关键的领域站住了脚。2017 年,OceanBase 开始走出支付宝、走出蚂蚁金服,在商业银行推广使用,至今已在数十家商业银行上线运行。


    从濒临解散到浴火重生,OceanBase 已经走了快十年,但在自研关系数据库这条漫漫长路上,OceanBase 才仅仅走出了一小步。在阳振坤看来,OceanBase 现在“开了很大的一朵花,但是结了很小的一个果”,虽然它已经向所有人证明了通用的分布式关系数据库是能够做成的,而且能真正应用在生产系统中,但今天 OceanBase 的应用还很有限,远远没有充分发挥它的价值。

    变局

    如今再回看十年前那场轰轰烈烈的 NoSQL 革命,很难一语判定它到底成功与否。从好的一面来看,在过去十年里,NoSQL 数据库确实取得了非常亮眼的成绩,在软件工程师阵营里越来越受欢迎,其中 MapReduce、Bigtable、Cassandra、MongoDB 等都是其中的佼佼者。然而这两年,业界也在重新拥抱 SQL,几乎所有的云计算服务提供商都在提供备受青睐的关系型数据库管理服务:例如 Amazon RDS、Google Cloud SQL、Azure PostgreSQL。对于亚马逊来说,其兼容 PostgreSQL 和 MySQL 的数据库产品 Aurora 一直是 AWS 历史上增长最快的服务。


    Gartner 在 2018 年的操作型数据库管理系统(OPDBMS)魔力象限中推测“到 2020 年,关系数据库技术将继续用于至少 70% 的新应用和新项目。”


    Gartner 过去四年对操作型数据库管理系统的分析,其中头部领导者 Oracle 和微软一直稳如磐石。正因为数据库领域的理论和工程实践早已成熟,前前后后各家公司做产品和技术的思路都差不多,所以很难突破现有产品的框架,更难以颠覆已有市场上占领先地位的厂商。


    但即使是数据库这样非常成熟的细分领域也发生了不少动荡,相比四年前,如今活下来的公司只剩下一半;谷歌凭借 Spanner 从一招鲜玩家杀入到远见者,阿里云一举跻身远见者,且拥有最多的 DBMS 服务品种;亚马逊连年快速上升,如今已经跟 Oracle、微软非常接近。


    阳振坤告诉我们,OceanBase 当初没有选择基于开源或已有的技术思路开发,而是选择走分布式自研这条路,虽然走得艰难,但做成之后就会成为不可替代的优势。过去这十来年正好是分布式系统发展的十来年,转型到分布式已经成为所有人都认可的一个选择。如今,以 Google Spanner、蚂蚁金服的 OceanBase 为代表的分布式关系数据库,不仅解决了关系数据库的扩展性问题,也极大地降低了关系数据库的成本(数量级的硬件成本的降低),还提升了可用性。


    现在,兼容 Oracle 的工作是 OceanBase 的重中之重。OceanBase 团队的目标是,用两年时间做到 Oracle 业务的平滑迁移,不需要修改一行代码、不需要业务做任何调整就能够将数据库迁移过来。


    对于数据库的未来,阳振坤表示:“尽管今天在业界,数据仓库主要依赖的不是关系数据库,但可以看看 Google。今天 Google 的大数据分析 / 数据库仓库基本都统一到了 Spanner,这应该是 5-10 年后产业界的写照。”未来,OceanBase 还会走得更快、更远。





    阳振坤还将担任 QCon 北京 2019《数据库与存储》专题的出品人,与大家探讨数据库和存储两个领域的最新技术架构和应用。部分精彩分享如下:


    OceanBase:云原生分布式数据库的技术挑战


    Baidu Table:新一代分布式 NoSQL 存储系统


    从自动化到自治-Oracle 优化案例实践和 19c 新特性揭秘


    面向异构存储的高性能键值数据库技术与挑战


    点击 链接 或识别二维码了解 QCon 十周年特别策划。大会报名倒计时,有任何问题欢迎联系票务小姐姐 Ring,电话:13269076283,微信:qcon-0410



    2019-04-17 08:008288
    用户头像
    蔡芳芳 InfoQ主编

    发布了 801 篇内容, 共 562.7 次阅读, 收获喜欢 2794 次。

    关注

    评论 2 条评论

    发布
    用户头像
    为什么没提到TiDB呢,这个不也是分布式关系型数据库吗?
    2019-04-17 14:07
    回复
    不是一个级别的东西。
    2019-04-18 10:26
    回复
    没有更多了
    发现更多内容

    偏头疼告诉我的,我想告诉每一个人

    zkback

    GitHub 上十个好用的软件

    彭宏豪95

    GitHub 效率 工具

    关于软件测试的三点思考

    卓然

    软件测试 测试 测试的价值 联现技术咖

    这场大数据+AI Meetup,一次性安排了大数据当下热门话题

    Apache Flink

    大数据 flink 流计算 实时计算

    前端工程化之创建项目

    春生

    大前端 全栈工程师

    地铁上看书的老外引发的思考

    小天同学

    写作 读书 个人感想 日常思考

    “新基建”方兴未艾,Smartbi Mining如何为产业数字化转型赋能?

    infoq小陈

    原创 | 使用JUnit、AssertJ和Mockito编写单元测试和实践TDD (十一)JUnit概述

    编程道与术

    Java 编程 软件测试 TDD 单元测试

    Server Queue 提高 QPS

    风含叶

    Python kafka 后端 队列

    如何通过样本数据推断其分布

    张利东

    Python

    自定义列表样式

    寇云

    CSS css3

    一款开源且具有交互视图界面的实时 Web 日志分析工具!

    JackTian

    开源 GoAccess 实时 Web 日志分析工具 交互式查看器

    为什么第三方联调应该先行?

    大伟

    git | IDEA 中如何压缩提交(压缩commit后再push 图文演示)

    YoungZY

    开发者工具 IDEA 开发工具

    写给产品经理的信(5):谈谈项目管理(青铜-王者)

    punkboy

    产品 极客时间,项目管理 项目管理 产品经理 项目

    写代码没几天,遇到一堆报错,我该怎么办

    刘早起😶

    Python 程序员 程序人生

    重学 Java 设计模式:实战原型模式

    小傅哥

    Java 设计模式 小傅哥 复杂代码优化 重构

    互联网省份数据大揭秘,看看哪些地方是互联网的戈壁滩?

    非著名程序员

    程序员 互联网 IT

    Python deepcopy一个优化

    么么哒

    Python

    HTML中实现合并单元格

    JDoe

    html

    做好领路人——写给技术新人的导师建议

    南方

    管理 新人

    团队与领导力健康检查 | 体检表

    Bob Jiang

    团队建设

    python实现·十大排序算法之基数排序(Radix Sort)

    南风以南

    Python 排序算法 基数排序

    券商也“网红”,证券行业IT服务运维发展按下“快进键”

    博睿数据

    运维 APM 证券 券商 行情

    只用CSS实现响应式Full-Width img 2种方法

    寇云

    CSS css3

    纯CSS“返回顶部”特效

    寇云

    CSS css3

    最香远程开发解决方案!手把手教你配置VS Code远程开发工具,工作效率提升N倍

    程序员柠檬

    Linux 后台开发 vscode 后端

    为什么要学习 Markdown?究竟有什么用?

    JackTian

    markdown markdown语法 markdown编辑器

    自定义构造python白名单__builtins__

    么么哒

    Python

    机器学习项目是如何开发和部署的?

    陆道峰

    人工智能 学习

    如何设计数据中台

    数据社

    大数据 数据中台 数据仓库

    支付宝背后的OceanBase:国产自研分布式数据库这十年_文化 & 方法_二叉树视频_InfoQ精选文章