Backup Tool
Backup Tool
1. Overview
The IoTDB Full Backup Tool is designed to create a full backup of a single IoTDB node’s data via hard links to a specified local directory. The backup can then be directly started and joined to the original cluster. The tool offers two modes: Quick Mirror Mode and Manual Backup Path Mode.
Notes:
- Stop the IoTDB service before starting the backup.
 - The script runs in the background by default, and logs are saved to log files during execution.
 - IoTDB version requirement: Must be v1.3.2 or higher.
 
2. Backup Modes
2.1 Mode 1: Quick Mirror Mode
Usage
backup.sh/backup.bat -quick -node xxx 
# Optional values for xxx are shown in the following examples
backup.sh/backup.bat -quick -node 
# Back up all nodes to the default path 
backup.sh/backup.bat -quick -node all 
# Back up all nodes to the default path 
backup.sh/backup.bat -quick -node confignode 
# Back up only the ConfigNode to the default path 
backup.sh/backup.bat -quick -node datanode 
# Back up only the DataNode to the default pathParameter Descriptions
| Parameter | Description | Required | 
|---|---|---|
-quick | Enables Quick Mirror Mode. | No | 
-node | Specifies the node type to back up. Options: all, datanode, or confignode. Default: all. all: Back up both DataNode and ConfigNode. datanode: Back up only the DataNode. confignode: Back up only the ConfigNode. | No | 
Process Details:
- Check if the 
_backupfolder already exists in the current IoTDB directory or paths specified in the configuration file. If it exists, the tool exits with the error:The backup folder already exists. 
When the backup folder already exists, you can try the following solutions:
- Delete the existing _backup folder and retry the backup.
 - Modify the backup path to avoid conflicts.
 
- Create hard links from the original 
dn_data_dirspaths to the corresponding_backuppaths.- Example: If 
dn_data_dirs=/data/iotdb/data/datanode/data, the backup data will be stored in/data/iotdb/data/datanode/data_backup. 
 - Example: If 
 - Copy other files from the IoTDB directory (e.g., 
/data/iotdb) to the_backuppath (e.g.,/data/iotdb_backup). 
2.2 Mode 2: Manual Backup Path Mode
Usage
backup.sh -node xxx -targetdir xxx -targetdatadir xxx -targetwaldir xxxParameter Descriptions
| Parameter | Description | Required | 
|---|---|---|
-node | Node type to back up (all, datanode, or confignode). Default: all. | No | 
-targetdir | Target directory for backing up the IoTDB folder. | Yes | 
-targetdatadir | Target path for dn_data_dirs files. Default: targetdir/data/datanode/data. | No | 
-targetwaldir | Target path for dn_wal_dirs files. Default: targetdir/data/datanode/wal. | No | 
Process Details:
The
-targetdirparameter is mandatory. If missing, the tool exits with the error:-targetdir cannot be empty. The backup folder must be specified.Validate consistency between configuration paths (
dn_data_dirs,dn_wal_dirs) and parameters (-targetdatadir,-targetwaldir):- If 
-targetdatadiror-targetwaldiris a single path, it is considered consistent. - If the number of source paths (from configuration) does not match the target paths, the tool exits with the error: 
-targetdatadir parameter exception: the number of original paths does not match the specified paths. 
- If 
 Check if
-targetdatadirpaths are on the same disk as the original paths:- Same disk: Attempt to create hard links. If hard links fail, copy files instead.
 - Different disk: Copy files directly.
 
Path Matching Rules
- Many-to-One: Multiple source paths can be backed up to a single target path.
 - One-to-One: A single source path can be backed up to a single target path.
 - Many-to-Many: Multiple source paths can be backed up to multiple target paths, but the pattern must match.
 
Examples
| Configuration Paths | -targetdatadir Paths | Result | 
|---|---|---|
/data/iotdb/data/datanode/data | /data/iotdb_backup/data/datanode/data | Consistent | 
/data/iotdb/data/datanode/data | /data/iotdb_backup/data/datanode/data1,/data/iotdb_backup/data/datanode/data2 | Inconsistent | 
/data/iotdb/data/datanode/data1,/data/iotdb/data/datanode/data2 | /data/iotdb_backup/data/datanode/data | Consistent | 
/data/iotdb/data/datanode/data1,/data/iotdb/data/datanode/data2 | /data/iotdb_backup/data/datanode/data3,/data/iotdb_backup/data/datanode/data4 | Consistent | 
/data/iotdb/data/datanode/data1,/data/iotdb/data/datanode/data2;/data/iotdb/data/datanode/data3 | /data/iotdb_backup/data/datanode/data | Consistent | 
/data/iotdb/data/datanode/data1,/data/iotdb/data/datanode/data2;/data/iotdb/data/datanode/data3 | /data/iotdb_backup/data/datanode/data1;/data/iotdb_backup/data/datanode/data1 | Consistent | 
/data/iotdb/data/datanode/data1,/data/iotdb/data/datanode/data2;/data/iotdb/data/datanode/data3 | /data/iotdb_backup/data/datanode/data1,/data/iotdb_backup/data/datanode/data3;/data/iotdb_backup/data/datanode/data | Consistent | 
/data/iotdb/data/datanode/data1,/data/iotdb/data/datanode/data2;/data/iotdb/data/datanode/data3 | /data/iotdb_backup/data/datanode/data1,/data/iotdb_backup/data/datanode/data3;/data/iotdb_backup/data/datanode/data1,/data/iotdb_backup/data/datanode/data4 | Inconsistent | 
Path Matching Rules Summary
- Paths separated by 
;only:-targetdatadircan be a single path (no;or,).-targetdatadircan also use;to split paths, but the count must match the source paths.
 - Paths separated by 
,only:-targetdatadircan be a single path (no;or,).-targetdatadircan also use,to split paths, but the count must match the source paths.
 - Paths with both 
;and,:-targetdatadircan be a single path (no;or,).- Split paths first by 
;, then by,. The number of paths at each level must match. 
 
Note: The
dn_wal_dirsparameter (for WAL paths) follows the same rules asdn_data_dirs.