写点什么

10 亿级流数据交互查询,为什么抛弃 MySQL 选择 VoltDB?

  • 2016-08-17
  • 本文字数:2503 字

    阅读完需:约 8 分钟

大数据时代,随着数据量的爆炸式增长,对于数据的处理速度要求也越来越高,以往基于 MySQL 的数据处理方案已无法满足大吞吐、低延迟的写入和高速查询的场景;百分点总结出了一套完整的解决方案,本文就带你一同了解 VoltDB 在流数据交互查询的应用实践。

流式数据交互查询场景

在百分点,每天有 10 亿条记录产生,针对这些大量实时产生的数据,不仅要做到实时写入,类似推荐调优、数据验证等查询要在秒级响应。有简单的单条验证,也有几个小时或一天的聚合计算,也有基于几千万 / 几亿数据表间的联合聚合查询。例如如下 SQL 查询:

对于前期的 MySQL 方案,虽然已经根据一定规则做了人工的分库,但是对于上面 SQL 中的表 Event 落在单机上的数据量达到几千万,Result 表也近千万,在这样的大表之间进行复杂的联合聚合查询,MySQL 查下来要花费 30 分钟左右,甚至更长,或是没响应了。

因此在针对同时要求大吞吐、低延迟的写入和高速查询的场景下,基于 MySQL 的现存方案完全无法实现。在不放弃 SQL 语句的便利基础上,经历过多种选型和方案调研,最终选择了 VoltDB 来解决此类问题。

如上图,线上的全量流量,通过 Streaming 总线同时到达 VoltDB 和离线 Hive 表。不同的是,数据写入 VoltDB 使用实时方式,写入 Hive 使用批量方式。新的数据要求在极短的延迟内马上写入 VoltDB 待查询;批量写入 Hive 的数据也可以做到小时级以内刷写到对应分区。

VoltDB 简介

VoltDB 是一种开源的极速的内存关系型数据库,由 Ingres 和 Postgres 联合创始人 Mike Stonebraker 带领开发的 NewSQL,提供社区版本和商业版本。VoltDB 采用 shard-nothing 架构,既获得了 NoSQL 的良好可扩展性以及高吞吐量数据处理,又没有放弃传统关系型数据库的事务支持—ACID。

一般 VoltDB 数据库集群由大量的站点 (分区) 组成,分散在多台机器上,数据的存储与处理都是分布在各个站点的,架构图如下所示:

如上图,集群有 3 个节点、每个节点 1 个站点构成。因此图中的表都只分成 3 个区,当然也可以分成更多的区,那么一张表在单个节点上则存在多个分区。

具体在使用上涉及以下几个概念

  • 客户端可以连接集群中任意一个节点,集群中所有节点是对等的,采用的也是水平分区的方式;

  • 每张表指定一个字段作为分区键,VoltDB 使用该键采用哈希算法方式分布表数据到各个分区。事实上 VoltDB 中存在两种类型的表,一种是分区表,还有一种叫做”Replicated table”。”Replicated 表”在每个节点存储的不是某张表的部分数据,而是全部数据,适用于小数据量的表。

    这里我们主要看重分区表,分区表的分区字段的选择很重要,应该尽量选择使数据分散均匀的字段。

VoltDB 支持的客户端语言或接口

  • C++
  • C#
  • Erlang
  • Go
  • Java
  • Python
  • Node.js
  • JDBC 驱动接口

HTTPJSON 接口 (这意味着所有能实现 http 请求语言,都能编写 VoltDB 的客户端程序,且非常直观)

VoltDB 的思想是,所有的事务都是由 java 实现的预编译存储过程完成,且所有的存储过程在任意站点上都是序列化执行的,这样使 VoltDB 达到了最高的隔离级别,且消除了锁的使用,很好地提高了处理速度。在官方的测试结果中,VoltDB 可以轻松的扩展到 39 台服务器 (300 核),120 个分区,每秒处理 160 万复杂事务。

百分点的实践

VoltDB 在百分点的使用如下图结构所示:

  • 数据从 Kafka 接入,补充下我们使用的是社区版本,社区版是没有持久化到磁盘功能的。因此使用 Kafka 非常适合,一旦出现故障,可以迅速从 Kafka 中恢复数据。
  • 使用 Storm 分布式实时计算框架,作为 VoltDB 的客户端,同时也是 Kafka 的消费者,充分利用 Storm 框架的高可用性和低延时特性。从数据产生,到进入 VoltDB,逐条写入延时在 16ms 内,如果优化成汇聚小 batch 写入,可以提升吞吐但降低写入延迟。

图中的 Zookeeper 保存数据写入 VoltDB 的规则配置,Storm 拓扑通过监听配置决定写入 VoltDB 的数据。由于需要根据业务场景,创建合理的 Schema、数据存储策略以及索引的应用。

例如,在不同表之间的关联查询,关联条件是变化的,可能用户在两表间需要根据商品进行关联查询,也可能会要求根据用户信息进行关联查询,但对于 VoltDB 来讲,在分区表间进行 Join 查询时还要求同时符合 VoltDB 分区规则;由于数据量大,数据结构也存在一定的差异,而 Storm 拓扑内存资源总是有限的。

于是我们采用了 Zookeeper 来做实时的动态配置,可以控制那些变化的数据进入 VoltDB,也可以控制数据进入不同的 Schema(本来是同一张表,但却使用了不同的分区策略而分成多个表)。

另外,VoltDB 目前还没有 TTL 的功能,我们构建自动剔除过期数据的程序,每隔 10 分钟删除一次最老的数据。这样一来,每天 10 亿条记录进出 VoltDB,时刻保持着 24 小时数据的 VoltDB 应用平台就构建起来了。如下是在测试环境上进行的写入测试:

CPU cores: 24

Machines: 4

Client threads: 64

经过在测试环境中运行,在 64 线程时压测达到了 100,000/s 的 TPS,机器的平均 CPU 使用率在 17% 左右,而且 VoltDB 的处理能力基本上随着机器数增加呈线性增长。在高吞吐写入过程中,执行日常查询工作可以达到 10 秒内。

上线后,部署 5 台机器,每台 384G 内存,同样 24 cpu cores。写入的峰值接近 70,000/s,相比原来同样的数据分布在 13 台 MySQL 机器上,在一台机器上 (也就是部分数据上) 花费 30 分钟的查询甚至使 MySQL 失去响应的复杂查询,到了 VoltDB 集群里基本上减少到十几秒,或者二十几秒,实现流式数据的交互查询。

总结

VoltDB 是一种性能极好的 OLTP 分布式内存 SQL 数据库,也存在一些缺陷,需要看使用场景,如其采用哈希的数据分布策略,进行范围查询可能不能体现出很大的优势。还有动态 SQL,不支持动态表指定等等。

数据库在大数据领域是核心组件,目前数据库产品非常多,可谓百花齐放,各有各的优势 / 不足,作为数据库的设计,关键还是要了解自己的需求,需要数据库来完成什么工作,再去理解每个数据库的功能和使用场景,这样才能根据需求选择合适的产品,设计出合理的 Schema。


感谢杜小芳对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2016-08-17 17:1218808

评论

发布
暂无评论
发现更多内容

中烟创新AI审核平台,打造烟草行业采购全链条合规管理新范式

中烟创新

远控安全进阶之战:TeamViewer/ToDesk/向日葵设备安全策略对比

小喵子

安全 远程办公 远程控制 ToDesk

昆仑万维天工超级智能体APP上线后爆火!全球首款Office智能体APP,开启AI办公新时代

新消费日报

前端热更新:无声引擎驱动中国互联网数字化转型

xuyinyin

高并发下如何防止商品超卖?

量贩潮汐·WholesaleTide

高并发

小白也能轻松上手:ToDesk、Parsec、AnyDesk、TeamViewer 哪款远程软件最适合新手?

小喵子

远程

通义灵码+云效 DevOps MCP:通过云效工作项自动生成代码并提交请求

阿里巴巴云原生

阿里云 云原生 通义灵码 MCP

一文就可搞清楚的HarmonyOS NEXT解锁模态页面的“真香”操作

程序员Feri

HarmonyOS NEXT

Java面试八股文大全(附各大厂面试真题及答案)

Geek_Yin

编程 程序员 java面试 Java面试题

5月 | 塞讯模拟攻击库更新汇总

塞讯科技

网络安全

深度解读「高盛」人形机器人双研报:主流人形机器人公司梳理和商业化瓶颈(附报告)

机器人头条

科技 大模型 人形机器人 具身智能

最全的Java面试八股文合集

Geek_Yin

编程 程序员 java面试 Java面试题

利用贝锐花生壳内网穿透,实现ComfyUI随时随地远程绘图

科技热闻

分布式数据库不是万能药,小心掉坑花冤枉钱!

科技热闻

使用 Run:ai Model Streamer 实现模型的高效加载

Se7en

ToDesk优惠码是什么,如何使用?

小喵子

优惠券 远程控制 ToDesk todesk、

超实用!Dify调用Java的3种实现方式!

王磊

Web3的成功离不开什么?

PowerVerse

去中心化 云算力 web3 #区块链

高德发布智能眼镜解决方案| 携手AR领军企业,引领智慧出行新未来

高德开放平台

AI AR loT 高德地图 AR眼镜

如何通过ETLCloud实现跨系统数据同步?

RestCloud

MySQL 数据库 数据同步 ETL 数据集成

告别“算不清的账”,甲方安全的“ROI 之痛”有救了!

塞讯科技

rol

方盒子对决:哈弗猛龙燃油版与捷途旅行者深度对比

科技热闻

全球科技巨头云集,展现AI前沿成果|2025深圳人工智能展

AIOTE智博会

高交会 高新技术展 深圳高交会

Java后台实现微信小程序不同人员生成不同小程序码并追踪扫码来源

电子尖叫食人鱼

Java 微信小程序

Vue3组件通信全攻略:多种方式详解+实战场景,轻松玩转复杂数据流!

量贩潮汐·WholesaleTide

JavaScript Vue 3

华南会议|最新日程,2025 Altair区域技术交流会,报名火热进行中!

Altair RapidMiner

人工智能 AI 汽车 数字孪生 CAE

通义灵码+云效 DevOps MCP:通过云效工作项自动生成代码并提交请求

阿里云云效

阿里云 通义灵码 MCP

百度网盘位列AI产品榜APP第一,AI激活网盘内容管理、消费新增量

极客天地

一种更简单的方式运行 C# 代码,简化 C# 开发体验!

不在线第一只蜗牛

C#

人工智能AI在数字化转型有哪些应用?

优秀

人工智能 AI 数字化转型

Web前端入门:JavaScript 循环结构注意事项

不在线第一只蜗牛

前端

10亿级流数据交互查询,为什么抛弃MySQL选择VoltDB?_数据库_谭正海_InfoQ精选文章