Back up and restore data
InfluxDB 3 Core persists all data and metadata to object storage. Back up your data by copying object storage files in a specific order to ensure consistency and reliability.
Currently, InfluxDB 3 Core does not include built-in backup and restore tools. Because copying files during periods of activity is a transient process, we highly recommended you follow the below procedures and copy order to minimize risk of creating inconsistent backups.
Supported object storage
InfluxDB 3 supports the following object storage backends for data persistence:
- File system (local directory)
- AWS S3 and S3-compatible storage (MinIO)
- Azure Blob Storage
- Google Cloud Storage
Backup and restore procedures don’t apply to memory-based object stores.
File structure
| Location | Description |
|---|---|
<node_id>/ | Root directory for all node state |
<node_id>/_catalog_checkpoint | Catalog state checkpoint file |
<node_id>/catalog/ | Catalog log files tracking catalog state changes |
<node_id>/wal/ | Write-ahead log files containing written data |
<node_id>/snapshots/ | Snapshot files summarizing persisted Parquet files |
<node_id>/dbs/<db>/<table>/<date>/ | Parquet files organized by database, table, and time |
<node_id>/table-snapshots/<db>/<table>/ | Table snapshot files (regenerated on restart, optional for backup) |
Backup process
Copy files in the recommended order to reduce risk of creating inconsistent backups. Perform backups during downtime or minimal load periods when possible.
Recommended backup order:
- Snapshots directory
- Database (dbs) directory
- WAL directory
- Catalog directory
- Catalog checkpoint file
#!/bin/bash
NODE_ID="NODE_ID"
DATA_DIR="/path/to/data"
BACKUP_DIR="/backup/$(date +%Y%m%d-%H%M%S)"
mkdir -p "$BACKUP_DIR"
# Copy in recommended order
cp -r $DATA_DIR/${NODE_ID}/snapshots "$BACKUP_DIR/"
cp -r $DATA_DIR/${NODE_ID}/dbs "$BACKUP_DIR/"
cp -r $DATA_DIR/${NODE_ID}/wal "$BACKUP_DIR/"
cp -r $DATA_DIR/${NODE_ID}/catalog "$BACKUP_DIR/"
cp $DATA_DIR/${NODE_ID}/_catalog_checkpoint "$BACKUP_DIR/"
echo "Backup completed to $BACKUP_DIR"Replace NODE_ID with your node ID.
This example works with Docker containers that use volume mounts for data persistence. Adjust the DATA_DIR path to match your volume mount configuration.
#!/bin/bash
NODE_ID="NODE_ID"
SOURCE_BUCKET="SOURCE_BUCKET"
BACKUP_BUCKET="BACKUP_BUCKET"
BACKUP_PREFIX="backup-$(date +%Y%m%d-%H%M%S)"
# Copy in recommended order
aws s3 sync s3://${SOURCE_BUCKET}/${NODE_ID}/snapshots \
s3://${BACKUP_BUCKET}/${BACKUP_PREFIX}/${NODE_ID}/snapshots/
aws s3 sync s3://${SOURCE_BUCKET}/${NODE_ID}/dbs \
s3://${BACKUP_BUCKET}/${BACKUP_PREFIX}/${NODE_ID}/dbs/
aws s3 sync s3://${SOURCE_BUCKET}/${NODE_ID}/wal \
s3://${BACKUP_BUCKET}/${BACKUP_PREFIX}/${NODE_ID}/wal/
aws s3 sync s3://${SOURCE_BUCKET}/${NODE_ID}/catalog \
s3://${BACKUP_BUCKET}/${BACKUP_PREFIX}/${NODE_ID}/catalog/
aws s3 cp s3://${SOURCE_BUCKET}/${NODE_ID}/_catalog_checkpoint \
s3://${BACKUP_BUCKET}/${BACKUP_PREFIX}/${NODE_ID}/
echo "Backup completed to s3://${BACKUP_BUCKET}/${BACKUP_PREFIX}"Replace the following:
NODE_ID: your node IDSOURCE_BUCKET: your InfluxDB data bucketBACKUP_BUCKET: your backup destination bucket
Restore process
Restoring overwrites existing data. Always verify you have correct backups before proceeding.
Recommended restore order:
- Catalog checkpoint file
- Catalog directory
- WAL directory
- Database (dbs) directory
- Snapshots directory
File system restore example
#!/bin/bash
NODE_ID="NODE_ID"
BACKUP_DIR="/backup/BACKUP_DATE"
DATA_DIR="/path/to/data"
# 1. Stop InfluxDB
systemctl stop influxdb3 || docker stop influxdb3-core
# 2. Optional: Clear existing data for clean restore
rm -rf ${DATA_DIR}/${NODE_ID}/*
# 3. Restore in reverse order of backup
mkdir -p ${DATA_DIR}/${NODE_ID}
cp ${BACKUP_DIR}/_catalog_checkpoint ${DATA_DIR}/${NODE_ID}/
cp -r ${BACKUP_DIR}/catalog ${DATA_DIR}/${NODE_ID}/
cp -r ${BACKUP_DIR}/wal ${DATA_DIR}/${NODE_ID}/
cp -r ${BACKUP_DIR}/dbs ${DATA_DIR}/${NODE_ID}/
cp -r ${BACKUP_DIR}/snapshots ${DATA_DIR}/${NODE_ID}/
# 4. Set correct permissions (important for Docker)
chown -R influxdb:influxdb ${DATA_DIR}/${NODE_ID}
# 5. Start InfluxDB
systemctl start influxdb3 || docker start influxdb3-coreReplace the following:
NODE_ID: your node IDBACKUP_DATE: backup directory timestamp (for example, 20240115-143022)
S3 restore example
#!/bin/bash
NODE_ID="NODE_ID"
BACKUP_BUCKET="BACKUP_BUCKET"
BACKUP_PREFIX="backup-BACKUP_DATE"
TARGET_BUCKET="TARGET_BUCKET"
# 1. Stop InfluxDB
# Implementation depends on your deployment method
# 2. Optional: Clear existing data for clean restore
aws s3 rm s3://${TARGET_BUCKET}/${NODE_ID} --recursive
# 3. Restore from backup
aws s3 sync s3://${BACKUP_BUCKET}/${BACKUP_PREFIX}/${NODE_ID}/ \
s3://${TARGET_BUCKET}/${NODE_ID}/
# 4. Start InfluxDB
# Implementation depends on your deployment methodReplace the following:
NODE_ID: your node IDBACKUP_DATE: backup timestampBACKUP_BUCKET: bucket containing backupTARGET_BUCKET: target bucket for restoration
Recovery expectations
Recovery succeeds to a consistent point in time, which is the latest snapshot included in the backup. Data written after that snapshot may not be present if its WAL was deleted after the backup. Any Parquet files without a snapshot reference are ignored.
Object storage features and backup planning
Versioning
If your object storage provider supports it, consider enabling short-term object versioning on the object store backing InfluxDB 3 Core — typically 1–2 days — to protect against errant writes or accidental deletions. With versioning enabled, the object store retains distinct versions of each updated object, which can be used to recover from these incidents.
InfluxDB 3 Core writes mostly immutable Parquet files and rarely updates existing objects, so versioning helps most with recovering specific accidentally deleted files. If many files are affected at once, recovering them through individual version restores becomes impractical.
Versioning costs grow with object update frequency. InfluxDB 3 Core’s compaction process generates new Parquet files over time, so each compaction pass adds to the retained version count in a versioned bucket. Use the shortest retention window that meets your recovery needs, and treat versioning as a short-window safety net rather than a long-term backup substitute.
Periodic backups
Provider-side features like versioning, soft delete, and point-in-time recovery protect against many failure modes but do not replace backups. Periodic backups to a separate object store remain the only predictable, repeatable way to recover from:
- Corruption or compromise of the primary object store.
- Accidental or malicious deletion of data.
- Bad data written into the primary store (a replica of bad data is not a valid recovery point).
The backup process above is provider-agnostic — you can use any provider-native tool to copy to a separate bucket, container, or account, as long as you preserve the documented directory structure and file ordering. Schedule copies during low-load periods or downtime windows when possible.
Containerized deployments
When running InfluxDB 3 Core in containers:
- Volume consistency: Use the same volume mounts for backup and restore operations
- File permissions: Ensure container user can read restored files (use
chownif needed) - Backup access: Mount a backup directory to copy files from containers to the host
Excluded files
Files in <node_id>/table-snapshots/ are intentionally excluded from backup:
- These files are periodically overwritten
- They regenerate automatically on server restart
- Including them doesn’t harm but increases backup size unnecessarily
Backup timing
- Perform backups during downtime or minimal load periods
- Copying files while the database is active may create inconsistent backups
- Consider using filesystem or storage snapshots if available
- Compression is optional but recommended for long-term storage
Was this page helpful?
Thank you for your feedback!
Support and feedback
Thank you for being part of our community! We welcome and encourage your feedback and bug reports for InfluxDB 3 Core and this documentation. To find support, use the following resources:
Customers with an annual or support contract can contact InfluxData Support.