博客
关于我
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/

你可能感兴趣的文章
OpenERP ORM 对象方法列表
查看>>
openEuler Summit 2022 成功举行,开启全场景创新新时代
查看>>
openEuler 正式开放:推动计算多样化时代的到来
查看>>
OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_openeuler切换root用户_su:拒绝权限_passwd: 鉴定令牌操作错误---国产瀚高数据库工作笔记001
查看>>
OpenEuler23.03欧拉系统_安装瀚高数据库企业版6.0.4_踩坑_安装以后系统无法联网_启动ens33网卡---国产瀚高数据库工作笔记002
查看>>
OpenFeign 入门与实战
查看>>
OpenFeign源码学习
查看>>
OpenFeign组件声明式服务调用
查看>>
openfeign远程调用不起作用解决_使用Spring Boot的spring.factories进行注入---SpringCloud Alibaba_若依微服务框架改造---工作笔记007
查看>>
openfire开发(四)消息拦截器
查看>>
openfire源码解读之将cache和session对象移入redis以提升性能
查看>>
Openfire身份认证绕过漏洞复现+利用(CVE-2023-32315)
查看>>
OpenForest 开源项目安装与使用指南
查看>>
OpenGL glBlendFunc() 设置颜色混合 透明度叠加计算
查看>>
opengl 深度详解,多重采样时,如何在OpenGL纹理中解析深度值?
查看>>
OpenGL 的内置矩阵种种
查看>>
OpenGL中shader读取实现
查看>>
OpenGL中旋转平移缩放等变换的顺序对模型的影响
查看>>
Opengl中的gluProject函数认识
查看>>
OpenGl介绍
查看>>