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