博客
关于我
Apache IoTDB源码解析(0.11.2版本):基本的数据结构解析(iotdb的内存表、存放的值)
阅读量:346 次
发布时间:2019-03-04

本文共 628 字,大约阅读时间需要 2 分钟。

IoTDB内存表模型与源码分析

1. 声明

本文旨在分享学习IoTDB源码的经历和收获,重点探讨其内存表的数据结构设计。所有内容源自于GitHub直接拉取的IoTDB开源项目源码。

2. AbstractMemTable源码分析

IoTDB采用HashMap作为内存表的基础数据结构,key为devcId(表示某个时序的前缀),value为另一个Map,用于存储时序后缀、时间戳集合以及数值集合。这种设计使得数据能够按照特定规则组织和检索。

3. IWritableMemChunk及子类源码解读

IWritableMemChunk类是IoTDB内存写入功能的核心实现,包含两个主要属性:MeasurementSchema(用于存储测点定义)和TVList(用于存储时序数据)。该类提供两种写入方式:单个数据写入和数组批量写入,分别通过相应的方法实现。

4. TVList及其子类分析

TVList位于org.apache.iotdb.db.utils.datastructure包下,作为时间序列数据的基础存储和排序接口。其子类BinaryTVList通过特定算法实现数据存储和索引计算,确保高效的时序数据管理和快速访问。

5. 内存表设计总结

IoTDB采用 HashMap管理内存表,devcId作为键,存储时序后缀及相关数据的Map作为值。TVList及其子类负责时序数据的存储和排序,通过两份数组分别管理时序和数值索引,确保数据的高效性和完整性。

转载地址:http://zcrh.baihongyu.com/

你可能感兴趣的文章
Panalog 日志审计系统 libres_syn_delete.php 前台RCE漏洞复现
查看>>
Springboot中@SuppressWarnings注解详细解析
查看>>
Panalog 日志审计系统 sprog_deletevent.php SQL 注入漏洞复现
查看>>
Panalog 日志审计系统 sprog_upstatus.php SQL 注入漏洞复现(XVE-2024-5232)
查看>>
Panalog 日志审计系统 前台RCE漏洞复现
查看>>
PANDA VALUE_COUNTS包含GROUP BY之前的所有值
查看>>
pandas - 如何将所有列从对象转换为浮点类型
查看>>
Pandas - 有条件的删除重复项
查看>>
pandas -按连续日期时间段分组
查看>>
pandas -更改重新采样的时间序列的开始和结束日期
查看>>
SpringBoot+Vue+Redis前后端分离家具商城平台系统(源码+论文初稿直接运行《精品毕设》)15主要设计:用户登录、注册、商城分类、商品浏览、查看、购物车、订单、支付、以及后台的管理
查看>>
pandas :to_excel() float_format
查看>>
pandas :加入有条件的数据框
查看>>
pandas :将多列汇总为一列,没有最后一列
查看>>
pandas :将时间戳转换为 datetime.date
查看>>
pandas :将行取消堆叠到新列中
查看>>
pandas :设置编号.最大行数
查看>>
pandas DataFrame 中的自定义浮点格式
查看>>
Pandas DataFrame 的 describe()方法详解-ChatGPT4o作答
查看>>
Pandas DataFrame中删除列级的方法链接解决方案
查看>>