docker 部署 Apache IoTDB

一、基本概念 IoTDB是一款针对时间序列数据收集、存储与分析一体化的数据管理引擎。它具有体量轻、性能高、易使用的特点,完美对接Hadoop与Spark生态,适用于工业物联网应用中海量时间序列数据高速写入和复杂分析查询的需求 。是一款专为物联网时序数据打造的数据库,提供数据采集、存储、分析的功能。它具有体量轻、性能高、易使用的特点,完美对接Hadoop与Spark生态,适用于工业物联网应用中海量时间序列数据高速写入和复杂分析查询的需求 。IoTDB是清华大学主导的Apache孵化项目,是Apache Flink、Apache Spark等大数据开源项目的核心组件之一。

IoTDB的架构采用存储和查询分离的架构,将底层存储开放给上层应用,一份数据既支持实时查询,也支持大数据分析,避免了数据迁移代价。
IoTDB的功能特点包括:

开放的架构:采用存储和查询分离的架构,将底层存储开放给上层应用,一份数据既支持实时查询,也支持大数据分析,避免了数据迁移代价。- 新型文件格式:采用了新型文件格式,支持高效的压缩和索引算法,提高了存储效率和查询速度。- 高性能:通过优化查询算法和数据结构,提高了查询效率和响应速度。- 易使用:支持SQL语言、JDBC标准API和易于使用的导入/导出工具。与先进的开放源码生态系统无缝集成。

二、docker下的部署

使用Docker来部署IotDB,并将其文件映射到/opt/IotDB目录下。

  1. 下载IoTDB的Docker镜像:在终端中输入以下命令,以从Docker Hub下载IoTDB的最新版本的Docker镜像:
bash 复制代码
docker pull apache/iotdb
  1. 创建一个本地目录,用于存储IoTDB的数据文件:
bash 复制代码
mkdir -p /data/IotDB
  1. 将本地目录挂载到容器中的/opt/IotDB目录下:
bash 复制代码
docker run -d \
  -p 6667:6667 \     # IoTDB 客户端端口(JDBC、Thrift协议)
  -p 31999:31999 \   # IoTDB 的DataNode RPC端口(集群间通信)
  -p 8181:8181 \     # IoTDB 的Web服务端口(监控、REST API)
  --name some-iotdb \ # 容器名称
  apache/iotdb \     # Docker镜像名称
  -m /data/IotDB     # 挂载点参数(指定数据存储路径)
  1. 现在,您可以将数据文件复制到本地目录中,并使用Tsfile格式进行存储。例如,将数据文件复制到/data/IotDB目录下:
bash 复制代码
cp your_data_file.tsfile /data/IotDB

5、进入容器:

bash 复制代码
docker exec -it some-iotdb /bin/bash
  1. 在IoTDB容器中启动Tsfile存储引擎:
bash 复制代码
start-tsfile.sh

开启 Mqtt 服务

进入iotdb的docker

bash 复制代码
docker exec -it ad9b18f8bff3 /bin/bash 

编辑配置文件

bash 复制代码
vi iotdb/conf/iotdb-engine.properties

开启服务,根据自己的需要,配置ip和端口等。

bash 复制代码
####################
### MQTT Broker Configuration
####################

# whether to enable the mqtt service.
enable_mqtt_service=false   # 修改成 true , 代表开启 mqtt服务

# the mqtt service binding host.
mqtt_host=0.0.0.0 # ip

# the mqtt service binding port.
mqtt_port=1883  # 端口

# the handler pool size for handing the mqtt messages.
mqtt_handler_pool_size=1

# the mqtt message payload formatter.
mqtt_payload_formatter=json  # 数据格式

# max length of mqtt message in byte
mqtt_max_message_size=1048576

重启服务,如果不会,就重启docker镜像。

iotdb 基础操作

bash 复制代码
启动服务: sbin/start-client.sh
root@ad9b18f8bff3:/iotdb/sbin# 
./start-cli.sh

官方仓库说明:

bash 复制代码
https://hub.docker.com/r/verdureorange/iotdb_arm

直接拉取镜像:

bash 复制代码
docker pull verdureorange/iotdb_arm:v0.13
相关推荐
sean9088 小时前
Colima 下 docker pull 失败自查流程
macos·docker·容器·colima
C182981825758 小时前
HttpURLConnection 是 Apache HttpClient 和 OKHttp 底层吗
okhttp·apache
斯普信专业组8 小时前
Docker Registry 镜像缓存与客户端无感加速(以 Docker Hub 为例)
缓存·docker·eureka
好大哥呀17 小时前
IoTDB详解
iotdb
学Linux的语莫19 小时前
docker,docker-compose二进制包安装
docker
_oP_i21 小时前
Docker 整体架构
docker·容器·架构
杨浦老苏21 小时前
可视化服务构建器Dock-Dploy
docker·工具·群晖
C1829818257521 小时前
restTemplate/Feign(Spring Cloud)或OKHttp Apache HttpClient 这几个关系与底层实现
spring cloud·okhttp·apache
落世繁华21 小时前
DIFY合同生成全流程开发实践(三、后端接口以及优化方向)
docker·一键部署·dify·合同生成·文字转word