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备份的数据也加载起来了

相关推荐
xcLeigh1 天前
IoTDB Rust 原生接口开发指南:从零生成 + 完整 RPC 调用
数据库·rpc·rust·接口·api·时序数据库·iotdb
回忆2012初秋9 天前
时序库.net平台下的推荐 SonnetDB,一文分析清除他与Apache IoTDB的区同
apache·iotdb
逍遥德10 天前
MQTT教程详解-03. 高级知识点
java·物联网·中间件·信息与通信·iot·iotdb
回忆2012初秋13 天前
.NET 时序数据操作实战:Apache IoTDB连接与 CRUD 完全指南
.net·apache·iotdb
百锦再13 天前
时序数据库选型指南:大数据时代的“数据基建”与 IoTDB 的工业原生之路
大数据·数据库·mysql·oracle·sqlserver·时序数据库·iotdb
檀越剑指大厂13 天前
时序数据库选型指南-IoTDB
数据库·时序数据库·iotdb
Francek Chen16 天前
【IoTDB】工业物联网时序数据库优选:Apache IoTDB的显著优势
大数据·数据库·物联网·时序数据库·iotdb
Apache IoTDB22 天前
Apache IoTDB V2.0.8 发布|新增模型并发推理,优化同步配置与安全加固
安全·apache·iotdb
Pocker_Spades_A23 天前
时序数据库选型指南:容量规划与压测方法(以 Apache IoTDB 为例)
apache·时序数据库·iotdb