从一到无穷大 #10 讨论 Apache IoTDB 大综述中看到的优劣势

这篇具有很好参考价值的文章主要介绍了从一到无穷大 #10 讨论 Apache IoTDB 大综述中看到的优劣势。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

从一到无穷大 #10 讨论 Apache IoTDB 大综述中看到的优劣势,从一到无穷大,时序数据库本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。

本作品 (李兆龙 博文, 由 李兆龙 创作),由 李兆龙 确认,转载请注明版权。

引言

在时序数据库这样一个小众的圈子里面每年有意思的东西并不多,每一篇顶会paper都值得细细品读。其次靠自己想很多问题很难解决,还是需要向业界优秀的团队虚心学习,才能清除和增加自己产品的核心竞争力。

问题定义

如下图是《Apache IoTDB: A Time Series Database for IoT Applications》中提出的一个典型场景:
从一到无穷大 #10 讨论 Apache IoTDB 大综述中看到的优劣势,从一到无穷大,时序数据库

  1. 边缘设备(时序数据的产生点)
  2. 边缘服务器中需要一个用于写入,存储和查询的数据库
  3. 云端的计算集群,用于OLAP分析

文章开篇指出了IotDB聚焦的问题,即:

  1. 不断变化的模式,即对于SchemaLess的支持(传感器经常被替换,移除,新增)
  2. 周期性的数据采集
  3. 强相关的series(利用2,3可以增加压缩的可能性)
  4. 多样化延迟数据的写入
  5. 高并发的数据写入

其次在优雅的解决这些问题能保证查询上做到:

  1. 一天之内10万数据点的selection在100ms
  2. 三年之内1000万数据点的aggregation在100ms

新技术

数据模型

InfluxDB中measurement+tags+fields的数据模型基本已经成为现实标准,但是IotDB认为这样的模型对于设备和传感器进行管理难以优化物理存储,遂使用树形管理所有的时间序列。

从一到无穷大 #10 讨论 Apache IoTDB 大综述中看到的优劣势,从一到无穷大,时序数据库
iotDB使用Sensor+Device管理所有的时间序列

物理模式如下:

  1. Time Series:每一条根节点到叶子结点是一个时间序列
  2. Series Family:一个设备的时间序列存储在一个tsfile中,一个tsfile中可以存储多个设备的时间序列,每一个 Series Family有一个独立的存储引擎,所有的tsfile存储在一个目录中

这样的优势我理解是可以控制哪些设备处于一个Series Family中,进而利用周期性和强相关的数据执行更有效的数据压缩。

schemaless

[12]中描述了iotdb的方案,后续有时间看下,influxdb的方案就很简单,不知道有什么区别。

Tsfile设计

从一到无穷大 #10 讨论 Apache IoTDB 大综述中看到的优劣势,从一到无穷大,时序数据库

  1. page:基本存储单位,一个page属于一个时间序列,其中存储两列,即时间和filed
  2. chunk:由metadata+多个page组成,所有page都属于一个时间序列
  3. chunk group:由metadata+多个chunk组成,所有的chunk属于一个或多个时间序列。多个chunk放在一起的原因文章中提到是一个设备所属的多个传感器一般被同时访问,
  4. index:很巧妙的组织形式,可以很快的索引某个时间序列的所有chunk信息,并且携带时间序列的统计信息,比如count,begin,end等,用于查询优化

本质上和TSM存储格式差不多,但是因为TSM是KV模型,依赖于TSI获取完整的seriesID,在这之中还需要在series file中获取时机的serieskey,这就很慢了。这也是现代时序数据库均使用Parquet,tsfile这样存储模型的原因,不仅导入导出方便,摆脱了倒排索引的依赖。

双MemTable

本质要解决的问题就是乱序数据会使得tsfile的时间区间存在重复,但是这只适用于乱序数据较少的情况,此时会有益于查询和写放大;否则会退化为普通版本,还增加了维护的开销。从一到无穷大 #10 讨论 Apache IoTDB 大综述中看到的优劣势,从一到无穷大,时序数据库在iotdb遇到的场景下,长延时只有0.0375%;但是在我们当前的场景中,乱序数据是常态;其次influxdb内数据的写入其实是在TSM,每个memtable中包含的是kv数据,就算乱序到达也只不过是查询时需要在level0中的多扫几个块罢了;
[10]中提到了可以通过数据的到达情况自动判断是否分裂,这对于iodDB来说确实是一种很好的思路。

高级可扩展查询

这几乎是领域龙头做的最好的一个方向了,因为这里非常偏学术,无论是DolphinDB还是IotDB对于各类特殊场景的算子支持都强于公有云厂商。

  1. 模式匹配算子PATTERN[2]
  2. 异常检测函数[3]
  3. 数据估算函数,用于填补空缺值[4][5]
  4. 用户自定义函数(UDF),用于特定领域个性化计算的需求;在查询引擎中算子的处理都是迭代器化的,这个其实我们也可以加,但是现阶段来看需求并不强烈,没必要透漏给用户这个接口。

其他

  1. 高效的数据传输,可以在边缘设备,边缘服务器和云端之间导入,不需要昂贵的ETL。这其实不是IotDB独有的优势,本质上只要存储层是独立可解释的文件就有这个优势,单很可惜inlfuxDB1.x不是,这也是InfluxData推动InfluxDBiox的关键动机之一。
  2. 高效的压缩能力,这其实是核心要解决的问题中周期性以及强相关数据的具体优化方式,在[6]中阐述了各种数据类型压缩的方式,iotdb也研究出了一些巧妙的压缩方式[7][8][9],也证明了一般时序数据库中默认(比如influxdb)的Timestamp: Delta → Scaling → (RLE/Simple8b); Float:XOR;Integer:ZigZag → (Simple8b/RLE/Uncompress);Boolean:Bit-packing;并不是最优的解决方案。但是这并不是IotDB独有的方案,理论上只需要一个实习生任意一个系统都可以具备这样的优势。其次存储目前从经验来看并不是运营中最大的问题,工程不是学术,在压缩率已经达到要求的情况下没有必要过度优化。

IotDB劣势

  1. 分布式系统设计历史气息浓厚,这带来的直接差异我能想到的有:元数据管理节点存在单点,集群规模TB级别,不适用于公有云,只适合于私有云,这也导致了价钱不会太便宜
  2. 聚焦于Iot场景,可以说把无损压缩做到了极致,但是现在SSD并不贵,以我们的运营经验来看存储不是瓶颈。优势带来的劣势时时间线较多的场景无法处理,因为tsfile中的树形索引基本失效,每一个series都是一个根节点。
  3. java编写,我猜测和influxdb1.x一样存在full gc的问题,基本无法解决;
  4. TSQL能力弱于influxql和SQL

influxDB 1.x 劣势

  1. 不支持SQL
  2. 基数无法无限扩展(国内目前TDengine以外其他大厂的时序数据库仔细看都存在时间线限制)
  3. 存算不分离(开源没有集群版),导致隔离很难做[13],基本上是无解的(也有办法,不过实施比较复杂),所以只能在运营角度规避这个问题
  4. go实现,且实现的不严谨,导致内存问题很严重;显然Rust/cpp才是最好的引擎语言
  5. 应该允许在没有本地存储的情况下运行,但是内部实现大量使用mmap(建议大家都看看[14])
  6. 索引数据分离,导致导入导出极为困难
  7. Highly indexed,导致写操作较为繁琐且昂贵,可能需要更新两个索引和一个数据
  8. 查询多时间线时极为昂贵,tsi中需要消耗大量的时间,因为需要对所有的查询条件的结果集做并集,并在seriesfile中查询series key,[15]也提到拆分索引是没有用的,查询的时间线客观存在,拆分索引还会造成内存问题,因为维护索引信息也需要不少内存
  9. 时间线较多时索引信息大于数据,但是时序的场景导致很多索引自始至终是无法被使用的

结束语

跟着老大InfluxDB IOX走基本上没有错,其他的路都是徒劳。
从一到无穷大 #10 讨论 Apache IoTDB 大综述中看到的优劣势,从一到无穷大,时序数据库

参考:文章来源地址https://www.toymoban.com/news/detail-646470.html

  1. Announcing InfluxDB IOx - The Future Core of InfluxDB Built with Rust and Arrow
  2. Kv-match: A subsequence matching approach supporting normalization and time warping icde2019
  3. Time series data cleaning: From anomaly detection to anomaly repairing vldb2017
  4. Sequential data cleaning: A statistical approach sigmod2016
  5. SCREEN: stream data cleaning under speed constraints sigmod2015
  6. Time series data encoding for efficient storage: A comparative analysis in apache iotdb vldb2022
  7. On aligning tuples for regression KDD22
  8. Grouping time series for efficient columnar storage sigmod2023
  9. Frequency domain data encoding in apache iotdb vldb2022
  10. Separation or not: On handing out-of-order time-series data in leveled lsm-tree icde2022
  11. Non-blocking raft for high throughput iot data icde2023
  12. Swapping repair for misplaced attribute values icde2020
  13. 从一到无穷大 #7 Database-as-a-Service租户隔离挑战与解决措施
  14. Are You Sure You Want to Use MMAP in Your Database Management System?
  15. The Design of InfluxDB IOx: In-Memory Columnar Database Written in Rust with Apache Arrow (Paul Dix)

到了这里,关于从一到无穷大 #10 讨论 Apache IoTDB 大综述中看到的优劣势的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • Kotlin协程-从一到多

    上一篇文章,我介绍了Kotlin协程的创建,使用,协作等内容。本篇将引入更多的使用场景,继续带你走进协程世界。 常用编程语言都会内置对同一类型不同对象的数据集表示,我们通常称之为容器类。不同的容器类适用于不同的使用场景。Kotlin的 Flow 就是在异步计算的需求下

    2024年02月09日
    浏览(11)
  • apache-iotdb-客户端(DBeaver-IoTDB、start-cli.bat)配置手册

    apache-iotdb-客户端(DBeaver-IoTDB、start-cli.bat)配置手册

    在使用iotdb时序库存储输数据时,由于iotdb无用户界面进行iotdb的数据库访问,需要用到客户端工具或第三方工具进行数据库数据操作,现对客户端及第三方工具的配置方式进行说明。 确定服务器中iotdb的版本,本地iotdb客户端命令行工具版本需要与服务器中iotdb的版本保持一致

    2024年02月02日
    浏览(9)
  • Apache IoTDB v1.3.0 发布|增加客户端服务器 SSL 通讯加密、写入负数时间戳等功能...

    Apache IoTDB v1.3.0 发布|增加客户端服务器 SSL 通讯加密、写入负数时间戳等功能...

    Release Announcement   Version 1.3.0   Apache IoTDB v1.3.0 已经发布,主要新增 SSL 通讯加密、数据同步监控项统计等新特性,优化了原有权限模块的语法和逻辑、metrics 算法库性能、Python 客户端写入性能以及在部分查询场景下的查询效率,修复部分产品 bug 和性能问题。 欢迎在我们的网

    2024年01月17日
    浏览(30)
  • Don’t Hold My Data Hostage – A Case For Client Protocol Redesign 论文阅读 & Apache IoTDB TsBlock 对比

    Don’t Hold My Data Hostage – A Case For Client Protocol Redesign 是 VLDB 2017 的一篇论文,主要着眼于数据库客户端协议的设计。本文主要是个人对论文的一些理解,以及结合自己较熟悉的开源时序数据库 Apache IoTDB 进行了一些对比分析。如果有谬误之处,欢迎留言指正~ 将大量级数据从

    2024年02月12日
    浏览(14)
  • Apache Hudi 1.x 版本重磅功能展望与讨论

    Apache Hudi 社区正在对Apache Hudi 1.x版本功能进行讨论,欢迎感兴趣同学参与讨论,PR链接:https://github.com/apache/hudi/pull/8679/files 此 RFC 提议对 Hudi 中的事务数据库层进行令人兴奋和强大的重构,以推动未来几年整个社区的持续创新。 在过去的几年里,社区成长(https://git-contributo

    2024年02月07日
    浏览(12)
  • 数据库原理及应用(MySQL版)MySQL实验指导参考答案(实验一到实验八)

    实验二 实验三 实验五 实验六 实验七 实验八

    2024年02月04日
    浏览(11)
  • Apache Doris 入门 10 问

    Apache Doris 入门 10 问

    基于 Apache Doris 在读写流程、副本一致性机制、 存储机制、高可用机制等方面的常见疑问点进行梳理,并以问答形式进行解答。在开始之前,我们先对本文相关的 名词 进行解释: FE :Frontend,即 Doris 的前端节点。主要负责接收和返回客户端请求、元数据以及集群管理、查询

    2024年02月02日
    浏览(17)
  • Apache Doris入门10问

    Apache Doris入门10问

    基于 Apache Doris 在读写流程、副本一致性机制、 存储机制、高可用机制等方面的常见疑问点进行梳理,并以问答形式进行解答。在开始之前,我们先对本文相关的 名词 进行解释: FE :Frontend,即 Doris 的前端节点。主要负责接收和返回客户端请求、元数据以及集群管理、查询

    2024年01月21日
    浏览(11)
  • Apache Wicket 9.10.0发布

    Apache Wicket 是一个开源的面向 Java 组件的 Web 应用框架,为政府、商店、大学、城市、银行、电子邮件提供商等成千上万的 Web 应用和网站提供支持。 Wicket 的开发中使用了语义版本,因此与 9.0.0 相比,9.10 版本没有出现 API 中断。 9.10 的更新内容包括: 错误修复 [WICKET-6970] -

    2024年01月22日
    浏览(8)
  • iotdb集群模式部署

    重要声明:部署的版本要和脚本对应上,这里可以点击 查看最新部署脚本:https://iotdb.apache.org/zh/UserGuide/latest/Deployment-and-Maintenance/Docker-Install.html 来获取最新的脚本; 我使用的是1.3.0版本的iotdb 下面是我基于三个节点的部署步骤: 假如有三台物理机,里面安装了centos系统,它

    2024年03月28日
    浏览(9)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包