IoTDB数据备份与恢复

iotdb A目录:/root/iotdb/apache-iotdb-2.0.6-all-bin

iotdb B目录:/root/iotdb/apache-iotdb-2.0.6-all-bin_2/apache-iotdb-2.0.6-all-bin

A与B的所有配置一样,都是单机模式,A中有数据,我需要将A的数据全部备份,然后把A关闭,然后把B打开,B要能全部加载A的数据

iotdb版本是 2.0.6

备份A的数据并关闭A
bash 复制代码
# 进入A目录
cd /root/iotdb/apache-iotdb-2.0.6-all-bin

# 停止A实例
./sbin/stop-standalone.sh

# 等待IoTDB完全停止
sleep 10

# 备份整个data目录
cp -r data/ /tmp/iotdb_data_backup/
# 或者压缩备份
tar -czvf /tmp/iotdb_data_backup.tar.gz data/

# 查看备份文件大小确认
du -sh /tmp/iotdb_data_backup/
2. 准备B的数据目录
shell 复制代码
# 进入B目录
cd /root/iotdb/apache-iotdb-2.0.6-all-bin_2/apache-iotdb-2.0.6-all-bin

# 停止B实例(如果正在运行)
./sbin/stop-standalone.sh

# 备份B的原始空数据目录(可选)
mv data/ data_backup/

# 复制A的数据到B
cp -r /root/iotdb/apache-iotdb-2.0.6-all-bin/data/ ./
3. 检查并确保配置文件一致
shell 复制代码
# 比较A和B的配置文件
cd /root/iotdb

# 比较主要配置文件
diff apache-iotdb-2.0.6-all-bin/conf/iotdb-system.properties \
     apache-iotdb-2.0.6-all-bin_2/apache-iotdb-2.0.6-all-bin/conf/iotdb-system.properties

# 比较数据目录配置
diff apache-iotdb-2.0.6-all-bin/conf/iotdb-common.properties \
     apache-iotdb-2.0.6-all-bin_2/apache-iotdb-2.0.6-all-bin/conf/iotdb-common.properties

特别注意检查以下配置项是否一致:

bash 复制代码
# 查看A的配置
grep -E "(data_dir|wal_dir|storage_group|timestamp_precision)" \
  apache-iotdb-2.0.6-all-bin/conf/iotdb-system.properties
  
# 查看B的配置
grep -E "(data_dir|wal_dir|storage_group|timestamp_precision)" \
  apache-iotdb-2.0.6-all-bin_2/apache-iotdb-2.0.6-all-bin/conf/iotdb-system.properties
4. 修改B的端口配置(避免与A冲突)

如果A和B需要在同一台机器上不同时运行,这步可跳过。如果要同时运行,需要修改端口:

bash 复制代码
# 修改B的conf/iotdb-common.properties
cd /root/iotdb/apache-iotdb-2.0.6-all-bin_2/apache-iotdb-2.0.6-all-bin

# 备份原始配置文件
cp conf/iotdb-common.properties conf/iotdb-common.properties.backup

# 修改端口(示例,将6667改为6668)
sed -i 's/rpc_port=6667/rpc_port=6668/' conf/iotdb-common.properties
sed -i 's/rpc_address=0.0.0.0/rpc_address=0.0.0.0/' conf/iotdb-common.properties
5. 启动B并验证数据
bash 复制代码
# 启动B实例
cd /root/iotdb/apache-iotdb-2.0.6-all-bin_2/apache-iotdb-2.0.6-all-bin
./sbin/start-standalone.sh

# 查看启动日志
tail -f logs/log_datanode_all.log

# 等待启动完成后,连接到B验证数据
./sbin/start-cli.sh -h 127.0.0.1 -p 6667

# 在CLI中执行验证命令
SHOW DATABASES;
COUNT DATABASES;
# 选择某个数据库查看时间序列
SHOW TIMESERIES;
# 查看存储组
SHOW STORAGE GROUP;

基本到这里就差不多了,现在启动的就是B,而且把A备份的数据也加载起来了

相关推荐
想你依然心痛3 天前
工业物联网云原生时代:时序数据库全链路选型与 Apache IoTDB 实践
物联网·云原生·时序数据库·iotdb
逍遥德3 天前
物联网-01-Spring Boot + MyBatis‑Plus 操作 IoTDB(表模型)
spring boot·物联网·iotdb
小学鸡!6 天前
IoTDB数据库导入导出数据
数据库·iotdb
xcLeigh13 天前
IoTDB JDBC 完整使用教程:连接、查询、批处理与字符集配置
开发语言·数据库·qt·iotdb·查询·批处理·连接
隔窗听雨眠14 天前
IoTDB与TimechoDB深度解析
时序数据库·iotdb·timechodb
攻城狮7号17 天前
时序数据库怎么选:从业务需求到 IoTDB 的一条线
数据库·时序数据库·iotdb·ai数据库
Apache IoTDB19 天前
时序数据库 IoTDB + 时序智能服务平台 TimechoAI 亮相中国核电信息技术高峰论坛
数据库·时序数据库·iotdb
wei_shuo21 天前
工业物联网数据中枢:TDengine 的云原生与智能分析进化之路
iotdb
xcLeigh24 天前
IoTDB Rust 原生接口开发指南:从零生成 + 完整 RPC 调用
数据库·rpc·rust·接口·api·时序数据库·iotdb
回忆2012初秋1 个月前
时序库.net平台下的推荐 SonnetDB,一文分析清除他与Apache IoTDB的区同
apache·iotdb