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

在这里插入图片描述本作品采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。

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

文章目录

  • 引言
  • 问题定义
  • 新技术
    • 数据模型
    • schemaless
    • Tsfile设计
    • 双MemTable
    • 高级可扩展查询
    • 其他
  • IotDB劣势
  • influxDB 1.x 劣势
  • 结束语

引言

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

问题定义

如下图是《Apache IoTDB: A Time Series Database for IoT Applications》中提出的一个典型场景:
请添加图片描述

  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认为这样的模型对于设备和传感器进行管理难以优化物理存储,遂使用树形管理所有的时间序列。

请添加图片描述
iotDB使用Sensor+Device管理所有的时间序列

物理模式如下:

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

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

schemaless

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

Tsfile设计

在这里插入图片描述

  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的时间区间存在重复,但是这只适用于乱序数据较少的情况,此时会有益于查询和写放大;否则会退化为普通版本,还增加了维护的开销。请添加图片描述在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走基本上没有错,其他的路都是徒劳。
在这里插入图片描述

参考:

  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)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/37532.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

两天入门Linux、搭建Spring环境 第一天

一、Linux简介 1.什么是Linux 一个操作系统,未来公司里面会用到、接触的新操作系统。 2.为什么学Linux (1)个人职务需要,肯定会接触到Linux (2)职业发展,以后的发展肯定需要掌握Linux的许多使用方法 3.学哪些内容 (1)Linux基本介绍 (2)…

EnableAutoConfiguration Attributes should be specified via @SpringBootApplic

在排除数据源加载时,发现这个注解EnableAutoConfiguration(exclude{DataSourceAutoConfiguration.class})会飘红 这是因为在SpringBootApplication中已经有EnableAutoConfiguration注解了; 所以把它改写成以下的格式即可

图像变形之移动最小二乘算法(MLS)

基本原理 基于移动最小二乘的图像变形是通过一组源控制点和目标控制点来控制变形,对于每一个待求变形后位置的点而言,根据预设的形变类型(如仿射变换、相似变换、刚性变换)求解一个最小二乘优化目标函数估计一个局部的坐标变换矩阵…

metaRTC7 demo mac/ios编译指南

概要 metaRTC7.0开始全面支持mac/ios操作系统,新版本7.0.023 mac os demo 包含有srs/zlm的推拉流演示。发布版自带了x64版第三方类库,arm版第三方类库还需开发者自己编译。 源码下载 下载文件metartc7.023.7z https://github.com/metartc/metaRTC/re…

基于Java+SpringBoot+Vue的网吧管理系统设计与实现(源码+LW+部署文档等)

博主介绍: 大家好,我是一名在Java圈混迹十余年的程序员,精通Java编程语言,同时也熟练掌握微信小程序、Python和Android等技术,能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架…

智头条|DFM-2大模型吹热智能家居,360安全云正式发布

行业动态 DFM-2大模型吹热智能家居 近期,思必驰行业语言计算大模型DFM-2正式发布,也带来了人机交互能力的提升和优秀的技术落地能力。DFM-2大模型与DUI平台结合推出DUI2.0,完成了对话式AI全链路技术的升级,推进深度产业应用。在智能家居领域,目前思必驰已与海信、长虹美菱、老…

实例038 设置窗体在屏幕中的位置

实例说明 在窗体中可以设置窗体居中显示,本例通过设置窗体的Left属性和Top属性可以准确设置窗体的位置。运行本例,效果如图1.38所示。 技术要点 设置窗体在屏幕中的位置,可以通过设置窗体的属性来实现。窗体的Left属性表示窗体距屏幕左侧的…

Makefile多个子文件夹

首先,目录结构: 其中根目录Makefile主要作用是调用其他子文件夹Makefile,每个子模块执行各自编译后在build文件夹下生成obj文件,最后再执行build文件夹下Makefile进行链接。 根目录Makefile: TARGET ACT_Drv ##SRC_D…

秦岭地形图、水系图、全景图

来源:头条留白sy,星球研究所等,转自:地理科学研究苑

kubernetes集群(k8s)之安装部署Calico 网络

目录 安装部署Calico 网络 (一)环境准备 (二)部署docker环境 (三)部署kubernetes集群 (四)部署Calico网络插件 安装部署Calico 网络 (一)环境准备 IP地…

【历史上的今天】8 月 15 日:苹果推出初代 iMac;谷歌收购摩托罗拉移动;Fuchsia 首次发布

整理 | 王启隆 透过「历史上的今天」,从过去看未来,从现在亦可以改变未来。 今天是 2023 年 8 月 15 日,在 1878 年的今天,我国第一套邮票发行。中国是一个文明古国,在邮政通信方面,有着悠久的历史。早在三…

分布式监控平台—zabbix

前言一、zabbix概述1.1 什么是zabbix1.2 zabbix的监控原理1.3 zabbix常见五个应用程序1.4 zabbix的监控模式1.5 监控架构1.5.1 C/S(server—client)1.5.2 server—proxy—client1.5.3 master—node—client 二、部署zabbix2.1 部署 zabbix server 端2.2 …

日常BUG——SpringBoot关于父子工程依赖问题

😜作 者:是江迪呀✒️本文关键词:日常BUG、BUG、问题分析☀️每日 一言 :存在错误说明你在进步! 一、问题描述 在父子工程A和B中。A依赖于B,但是A中却无法引入B中的依赖,具体出现的…

Kubernetes 部署DolphinScheduler 创建租户失败

创建租户 报错创建租户失败。后台日志如下 源代码跟踪 org.apache.dolphinscheduler.api.service.impl.TenantServiceImpl / if hdfs startup if (PropertyUtils.getResUploadStartupState()) {createTenantDirIfNotExists(tenantCode); }需要将 resource.storage.type 置为…

【数据结构】队列及其实现

目录 1.队列的概念及结构 2.队列的实现 2.1队列结构定义 2.2队列的初始化及销毁 2.3数据入队 2.4数据出队 2.5访问队头数据 2.6访问队尾数据 2.6判断队列是否为空 2.7求队列的大小 2.7打印队列 1.队列的概念及结构 队列:只允许在一端进行插入数据操作&…

与微服务平台厂家联手,一起实现高效率发展!

在如今的快节奏发展社会中,只有利用科技的力量,才能与市场接轨,了解市场和客户需求,最终实现更快速的发展。如果还停留在闭门造车的环境中,不“引进来,走出去”,那势必会与成功擦肩而过。微服务…

clickHouse部署

docker仓库地址 https://hub.docker.com/ 1、docker环境搭建 # 1.先安装yml yum install -y yum-utils device-mapper-persistent-data lvm2 # 2.设置阿里云镜像 sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo# 3.查…

【芯片前端】auto_testbench的大版本升级——加入简单预期与自动比对

前言 前文提要: 【芯片前端】一键生成简易版本定向RTL验证环境的脚本——auto_verification_rtl脚本_尼德兰的喵的博客-CSDN博客 【芯片前端】可能是定向验证的巅峰之作——auto_testbench_autotestbench_尼德兰的喵的博客-CSDN博客 工具路径: auto…

广告聚合平台能为APP开发者提供哪些帮助

应用变现平台是帮助开发者优化广告策略并最终获得更多收入的综合途径。在广告变现过程中,接入单一的广告联盟,变现效率不高,并且开发者需要花费许多精力进行筛选和管理,难免会应接不暇,而聚合广告平台的出现则一定程度…

GloVe、子词嵌入、BPE字节对编码、BERT相关知识(第十四次组会)

GloVe、子词嵌入、BPE字节对编码、BERT相关知识(第十四次组会) Glove子词嵌入上游、下游任务监督学习、无监督学习BERTGlove 子词嵌入 上游、下游任务 监督学习、无监督学习 BERT