带你涨知识,认识一下打破世界纪录的数据库OceanBase!
本期为我们带来分享的嘉宾是 OceanBase总架构师,蚂蚁金服研究员 杨传辉(日照) 先生,本次嘉年华上,杨老师为我们带来题为: OceanBase 金融级分布式关系数据库 主题分享。下面,让我们跟随涛哥的采访走进杨传辉老师的世界里吧。
成都创新互联是少有的网站制作、网站设计、营销型企业网站、微信平台小程序开发、手机APP,开发、制作、设计、买链接、推广优化一站式服务网络公司,于2013年开始,坚持透明化,价格低,无套路经营理念。让网页惊喜每一位访客多年来深受用户好评
在2018年8月举行的亚运会女子50米仰泳比赛中,中国队的刘湘以26秒98的成绩打破世界女子50米仰泳尘封9年的世界纪录,在赛场上刮起了中国旋风。
一年之后的2019年10月2日,在另一个特殊的赛场上,中国人又破了一项尘封9年的世界纪录——全球数据库领域最权威的国际事务处理性能委员会(TPC)在其官网上宣布,阿里巴巴/蚂蚁金服的分布式关系数据库OceanBase打破数据库基准性能测试(TPC-C)的世界纪录,其tpmC值超过6000万,是前世界纪录保持者Oracle数据库的两倍。
新的纪录还在不断刷新之中。 今年的天猫“双11”总成交额达2684亿元,订单峰值54.4万笔/秒,支付宝数据库处理峰值达到6100万次/秒,再次刷新世界纪录。 这次的特别之处在于,这是在阿里巴巴核心系统100%上云的情况完成的创纪录之举。
俗话说,外行看热闹,内行看门道。 当你为天猫“双11”总成交额又创世界纪录疯狂打Call之时,可否注意到这背后,除了阿里云平台稳定、线性的输出以外,还有OceanBase的优异表现?
又是一年 “ 双11 ”
OceanBase“三大创举”
2017年对于OceanBase数据库来说是一个重要的转折点,在这一年,OceanBase数据库第一次“走出”阿里巴巴和蚂蚁金服,应用于南京银行互联网核心系统。 按照通用型商业数据库的发展思路打造分布式数据库,OceanBase身上的担子更重了。 分布式数据库能够在功能和性能上与传统集中式数据库分庭抗礼吗? 分布式数据库能够胜任企业核心业务,尤其是金融机构的核心业务吗?
OceanBase数据库用TPC-C测试结果给出了明确的答案。
PK传统数据库
站在同一水平线上
众所周知,TPC-C测试号称数据库领域的世界杯,是全球公认的数据库在线交易处理性能评价的通用指标。 TPC-C有一套严格的评测体系和标准,它采用图灵奖得主Jim Gray主导提出的DebitCredit模型,由TPC组织制定TPC系列标准,并监督审核测试过程和结果。 测试模拟订单创建与支付,规定五种事务发生比例,所有参测的数据库必须经过先功能后性能的测试,要求系统必须保证长时间稳定运行(8小时平稳运行,至少2小时性能波动小于2%)。 据杨传辉介绍,TPC-C拥有严格的审计流程,经过前期规划、测试准备、现场预审计、最终审计,最后还有60天公示期。 OceanBase是第一个通过TPC-C审计的分布式无共享关系数据库,审计时间超过半年,全球共3个审计员,2个审计员联合审计通过。
特别值得一提的是,此次TPC-C测试是在阿里云标准云资源的支持下实现的,改变了以前高性能测试结果都依赖专用集中式存储设备和专用高端服务器的实现方式,以完全分布式的软件架构创造了新的世界纪录。
杨传辉介绍说,TPC-C测试对于分布式数据库来说是一道难关。 因为交易处理即事务的ACID(原子性、一致性、隔离性和持久性)是标准的根本要求,而一直以来这都是通过传统的集中式系统实现的,分布式数据库要以分布式、多机的架构满足事务ACID,这是一个巨大的挑战。 而OceanBase在测试中打破性能纪录充分说明,分布式数据库在功能和性能上具备了与业内顶尖的传统单机数据库PK的能力,双方站在同一个水平线上。
走开放道路
OceanBase经过市场充分验证
对于OceanBase是否会开源,杨传辉的回答非常肯定: “OceanBase的策略不是开源,而是开放。 OceanBase最早的开源版本还停留在0.4,现在通过TPC-C测试的版本与之前的开源版本已经是天壤之别。 就像Oracle数据库并不开源,但是通过形式多样的开放的交流、沟通、培训等,大量的DBA对Oracle数据库的熟悉、理解和掌握程度甚至超过MySQL。 OceanBase所说的开放,与Oracle类似,目的是让更多的DBA能够更深入地理解和掌握OceanBase。 实际上,企业用户需要的并不是源代码,而是能够解决其业务问题的企业服务。 OceanBase走开放的道路,就是为了给企业客户提供有保障的企业级数据库服务。 ”
分享题目:带你涨知识,认识一下打破世界纪录的数据库OceanBase!
当前地址:http://ybzwz.com/article/ghppig.html