Apache IoTDB(5):深度解析时序数据库 IoTDB 在 AINode 模式单机和集群的部署与实践

Apache IoTDB(5):深度解析时序数据库 IoTDB 在 AINode 模式单机和集群的部署与实践

引言

Apache IoTDB 设计之初就专为物联网(IoT)场景而生,旨在提供一个集高性能数据写入、海量数据存储、低延迟分析查询于一体的一站式解决方案。

Apache IoTDB 时序数据库【系列篇章】

No.文章地址(点击进入)
1Apache IoTDB(1):时序数据库介绍与单机版安装部署指南
2Apache IoTDB(2):时序数据库 IoTDB 集群安装部署的技术优势与适用场景分析
3Apache IoTDB(3):时序数据库 IoTDB Docker部署从单机到集群的全场景部署与实践指南
4Apache IoTDB(4):深度解析时序数据库 IoTDB 在Kubernetes 集群中的部署与实践指南

一、IoTDB——AINode介绍

AINode 是 IoTDB 在 ConfigNode、DataNode 后提供的第三种内生节点,通过与 IoTDB 集群的 DataNode、ConfigNode 的交互,扩展了对时间序列进行机器学习分析的能力,支持从外部引入已有机器学习模型进行注册,并使用注册的模型在指定时序数据上通过简单 SQL 语句完成时序分析任务的过程,将模型的创建、管理及推理融合在数据库引擎中

在这里插入图片描述

AINode 是 IoTDB 集群外的额外套件,独立安装包

两种部署模式

集群模式

在这里插入图片描述

单机模式:

在这里插入图片描述

二、安装准备

2.1 安装包下载

AINode 安装包:apache-iotdb-2.0.5-ainode-bin.zip(点击下载)

在这里插入图片描述

安装包解压后目录

目录类型说明
lib文件夹AINode 的 python 包文件
sbin文件夹AINode的运行脚本(启动/移除/停止)
conf文件夹配置文件及运行环境设置脚本
LICENSE文件证书
NOTICE文件提示
README_ZH.md文件Markdown格式中文说明
README.md文件使用说明

2.2 环境准备

IoTDB 版本:>= V 2.0.5.1
Python 版本:3.9 ~3.12
工具: pip 和 venv

三、AINode 安装部署

3.1 安装

将 AINode 下载到专用目录后,切换到该目录并解压安装包

unzip apache-iotdb-<version>-ainode-bin.zip 

3.2 参数调整

可以通过修改 conf/iotdb-ainode.properties 文件中的参数来调整 AINode 配置。以下参数支持持久化修改

名称描述类型默认值
cluster_nameAINode要加入集群的标识stringdefaultCluster
ain_seed_config_nodeAINode启动时注册的ConfigNode地址String127.0.0.1:10710
ain_cluster_ingress_addressAINode拉取数据的DataNode的rpc地址String127.0.0.1
ain_cluster_ingress_portAINode拉取数据的DataNode的rpc端口Integer6667
ain_cluster_ingress_usernameAINode拉取数据的DataNode的客户端用户名Stringroot
ain_cluster_ingress_passwordAINode拉取数据的DataNode的客户端密码Stringroot
ain_cluster_ingress_time_zoneAINode拉取数据的DataNode的客户端时区StringUTC+8
ain_inference_rpc_addressAINode提供服务与通信的地址String127.0.0.1
ain_inference_rpc_portAINode提供服务与通信的端口String10810
ain_system_dirAINode元数据存储路径Stringdata/AINode/system
ain_models_dirAINode存储模型文件的路径Stringdata/AINode/models
ain_thrift_compression_enabledAINode是否启用thrift压缩机制Boolean0

3.3 加载模型权重

联系天谋团队获取模型权重文件,并将其存放至/IOTDB_AINODE_HOME/data/ainode/models/weights/目录中

3.4 启动 AINode

完成 Seed-ConfigNode 部署后,您可通过添加 AINode 节点实现模型注册与推理功能。配置 IoTDB 集群信息后,运行相应指令即可启动 AINode 并加入集群

注:联网环境启动

启动命令

  1. Linux 和 MacOS 系统
bash sbin/start-ainode.sh 
  1. Windows 系统
 sbin\start-ainode.bat 

后台启动命令(长期推荐)

  1. Linux 和 MacOS 系统
nohupbash sbin/start-ainode.sh > myout.file 2>&1&
  1. Windows 系统
nohupbash sbin\start-ainode.bat > myout.file 2>&1&

3.5 检测 AINode 节点状态

AINode 启动时会自动加入 IoTDB 集群。启动后,您可以通过执行 SQL 命令进行查询验证。当集群中显示该 AINode 节点状态为"Running"时,即表示节点已成功加入

在这里插入图片描述

3.6 停止 AINode

停止命令

  1. Linux / MacOS
bash sbin/stop-ainode.sh 
  1. Windows
 sbin\stop-ainode.bat 

停止 AINode 后,在集群中看到 AINode 节点,其运行状态为 UNKNOWN 表示该节点已经停止,没办法进行使用了

在这里插入图片描述

四、避坑指南

以下是之前博主安装时踩的一些坑,如有相似问题可以查询此处解决

4.1 启动AINode时出现找不到venv模块的报错

问题处理:在本地安装 venv 模块,以 ubuntu 为例,可以通过运行以下命令来安装 python 自带的 venv 模块。或者从 python 官网安装一个自带 venv 的 python 版本

apt-getinstall python3.10-venv 

4.2 pip版本低

windows下出现类似“error:Microsoft Visual C++ 14.0 or greater is required…”的报错,版本低导致

问题处理

./python -m pip install --upgrade pip ./python -m pip install --upgrade setuptools 

五、结语

Apache IoTDB 时序数据库中 AINode 工具采用分布式架构实现高可用性,支持水平扩展;内置智能数据处理引擎,可自动优化查询性能;提供实时流式分析能力,低延迟处理时序数据;兼容标准SQL语法,降低学习成本;支持多协议接入,便于与各类IoT设备集成。这些特性使其成为工业物联网场景下的高效时序数据库解决方案。本文详细讲述了AINode 的部署,后续博主会详细的介绍数据库管理以及具体的实操SQL语句等~

Read more

Flutter for OpenHarmony:Flutter 三方库 very_good_cli 打造企业级鸿蒙工程规范(标准化开发利器)

Flutter for OpenHarmony:Flutter 三方库 very_good_cli 打造企业级鸿蒙工程规范(标准化开发利器)

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 前言 在进行大中型 OpenHarmony 项目开发时,如何保证团队代码风格统一?如何快速搭建一个包含测试、Lint 规范、多环境配置的工程底座?官方的 flutter create 虽然好用,但它生成的只是一个“毛坯房”。 very_good_cli 是由知名的 Very Good Ventures 团队推出的命令行工具。它能一键生成“精装修”的 Flutter 项目模板,内置了严格的 Lint 规则、100% 测试覆盖率要求以及清晰的架构分层。对于追求高可靠性的鸿蒙应用,它是建立开发标准的最佳起点。 一、核心价值体系 very_good_cli 不仅仅是一个脚手架,它代表了一套工程哲学。 very_good create

By Ne0inhk
Flutter 组件 pos 适配鸿蒙 HarmonyOS 实战:ESC/POS 硬件协议通信,构建高性能零售收银与物联网打印架构

Flutter 组件 pos 适配鸿蒙 HarmonyOS 实战:ESC/POS 硬件协议通信,构建高性能零售收银与物联网打印架构

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 组件 pos 适配鸿蒙 HarmonyOS 实战:ESC/POS 硬件协议通信,构建高性能零售收银与物联网打印架构 前言 在鸿蒙(OpenHarmony)生态迈向专业收银终端、涉及智慧零售设备、数字化仓储标签打印及餐饮自助化服务的背景下,如何实现与热敏打印机(Thermal Printer)等硬件设备的底噪、高可靠通讯,已成为决定商业应用“交易闭环效率”的关键。在鸿蒙设备这类强调硬件直控能力(Raw IO)与实时系统响应的环境下,如果应用依然依赖图形化的截屏打印或低效的中间件转发,由于由于图像编解码的巨大算力消耗,极易由于由于“内存瞬时溢出”导致收银终端在高峰期发生严重卡顿。 我们需要一种能够直接生成热敏指令流(Hex Commands)、支持多种传输通道(蓝牙/Wi-Fi/USB)且符合行业标准(ESC/POS)的高性能控制方案。 pos

By Ne0inhk
OpenClaw下载安装配置|Windows安装流程|macOS 安装流程|Telegram 集成使用|飞书集成使用|常见坑和注意事项保姆级教程

OpenClaw下载安装配置|Windows安装流程|macOS 安装流程|Telegram 集成使用|飞书集成使用|常见坑和注意事项保姆级教程

🦞 OpenClaw 保姆级部署教程:Windows/macOS 全平台安装 + Telegram/飞书双端集成实战 作者:猫头虎AI | 阅读时间:约 25 分钟 | 难度:⭐⭐⭐☆☆ 因为🦞实在太火了,加上看多了AI相关的东西搞得人很焦虑,所以还是打算自己部署一下找点自我安慰吧🤷。先不说我能用来干啥,就想探一探它这么火的原因😮‍💨 在Windows中折腾了一天,终于算是初步跑通了,并配置了 Telegram 和 飞书 两个 channel。本文将完整记录从环境准备到多平台集成的全流程,帮你避开我踩过的所有坑。 OpenClaw 是一个适用于任何操作系统的 AI 智能体 Gateway 网关,支持 WhatsApp、Telegram、Discord、飞书等多种聊天应用。 📋 阅读目录 * 🦞 OpenClaw 保姆级部署教程:Windows/macOS 全平台安装 + Telegram/飞书双端集成实战 * 安装前准备

By Ne0inhk
时序数据库 Apache IoTDB:从边缘到云端Apache IoTDB 全链路数据管理能力、部署流程与安全特性解读

时序数据库 Apache IoTDB:从边缘到云端Apache IoTDB 全链路数据管理能力、部署流程与安全特性解读

时序数据库 Apache IoTDB:从边缘到云端Apache IoTDB 全链路数据管理能力、部署流程与安全特性解读 前言 大数据与物联网技术飞速发展的今天,时序数据呈现出爆发式增长的态势,从工业传感器的实时监控数据到智能设备的运行日志,从金融交易的时序记录到新能源汽车的工况数据,时序数据已成为企业数字化转型的核心资产,选择一款合适的时序数据库,直接关系到数据存储效率、分析能力与业务价值挖掘。 本文将从时序数据库的核心需求出发,结合大数据场景特点,通过与国外主流产品的对比分析,重点阐述 Apache IoTDB 在选型中的核心优势。 Apache IoTDB 介绍 Apache IoTDB 是由中科院软件所主导研发的开源时序数据库,专为物联网与工业大数据场景设计,以高性能、轻量级、易扩展为核心特点,通过三层数据模型与多级存储引擎,实现对海量时序数据的高效存储、快速查询与全生命周期管理,已成为国产化时序数据管理的标杆产品 ✅极致的性能表现:采用 TsFile 存储结构与多维索引体系,单节点每秒可处理数百万数据点写入,复杂聚合查询响应达毫秒级,结合差值编码等压缩算法,数据压缩

By Ne0inhk