Backup and restore
- Backup to a local disk
- Configuring backup/restore to use an S3 endpoint
- Backup/restore using an S3 disk
- Alternatives
Command summary
Prior to version 23.4 of ClickHouse, ALL was only applicable to the RESTORE command.
Background
While replication provides protection from hardware failures, it does not protect against human errors: accidental deletion of data, deletion of the wrong table or a table on the wrong cluster, and software bugs that result in incorrect data processing or data corruption. In many cases, mistakes like these will affect all replicas. ClickHouse has built-in safeguards to prevent some types of mistakes — for example, by default you can't just drop tables with a MergeTree-like engine containing more than 50 Gb of data. However, these safeguards do not cover all possible cases and can be circumvented.
In order to effectively mitigate possible human errors, you should carefully prepare a strategy for backing up and restoring your data in advance.
Each company has different resources available and business requirements, so there's no universal solution for ClickHouse backups and restores that will fit every situation. What works for one gigabyte of data likely won't work for tens of petabytes. There are a variety of possible approaches with their own pros and cons, which will be discussed below. It is a good idea to use several approaches instead of just one in order to compensate for their various shortcomings.
Keep in mind that if you backed something up and never tried to restore it, chances are that restore will not work properly when you actually need it (or at least it will take longer than business can tolerate). So whatever backup approach you choose, make sure to automate the restore process as well, and practice it on a spare ClickHouse cluster regularly.
Backup to a local disk
Configure a backup destination
In the examples below you will see the backup destination specified like Disk('backups', '1.zip').  To prepare the destination add a file to /etc/clickhouse-server/config.d/backup_disk.xml specifying the backup destination.  For example, this file defines disk named backups and then adds that disk to the backups > allowed_disk list:
Parameters
Backups can be either full or incremental, and can include tables (including materialized views, projections, and dictionaries), and databases. Backups can be synchronous (default) or asynchronous. They can be compressed. Backups can be password protected.
The BACKUP and RESTORE statements take a list of DATABASE and TABLE names, a destination (or source), options and settings:
- The destination for the backup, or the source for the restore.  This is based on the disk defined earlier.  For example Disk('backups', 'filename.zip')
- ASYNC: backup or restore asynchronously
- PARTITIONS: a list of partitions to restore
- SETTINGS:
- id: the identifier of a backup or restore operation. If it's unset or empty then a randomly generated UUID will be used. If it's explicitly set to a nonempty string then it should be different each time. This- idis used to find rows in table- system.backupsrelated to a specific backup or restore operation.
- compression_methodand compression_level
- passwordfor the file on disk
- base_backup: the destination of the previous backup of this source. For example,- Disk('backups', '1.zip')
- use_same_s3_credentials_for_base_backup: whether base backup to S3 should inherit credentials from the query. Only works with- S3.
- use_same_password_for_base_backup: whether base backup archive should inherit the password from the query.
- structure_only: if enabled, allows to only backup or restore the CREATE statements without the data of tables
- storage_policy: storage policy for the tables being restored. See Using Multiple Block Devices for Data Storage. This setting is only applicable to the- RESTOREcommand. The specified storage policy applies only to tables with an engine from the- MergeTreefamily.
- s3_storage_class: the storage class used for S3 backup. For example,- STANDARD
- azure_attempt_to_create_container: when using Azure Blob Storage, whether the specified container will try to be created if it doesn't exist. Default: true.
- core settings can be used here too
 
Usage examples
Backup and then restore a table:
Corresponding restore:
The above RESTORE would fail if the table test.table contains data, you would have to drop the table in order to test the RESTORE, or use the setting allow_non_empty_tables=true:
Tables can be restored, or backed up, with new names:
Incremental backups
Incremental backups can be taken by specifying the base_backup.
Incremental backups depend on the base backup. The base backup must be kept available in order to be able to restore from an incremental backup.
Incrementally store new data. The setting base_backup causes data since a previous backup to Disk('backups', 'd.zip') to be stored to Disk('backups', 'incremental-a.zip'):
Restore all data from the incremental backup and the base_backup into a new table test.table2:
Assign a password to the backup
Backups written to disk can have a password applied to the file:
Restore:
Compression settings
If you would like to specify the compression method or level:
Restore specific partitions
If specific partitions associated with a table need to be restored these can be specified. To restore partitions 1 and 4 from backup:
Backups as tar archives
Backups can also be stored as tar archives. The functionality is the same as for zip, except that a password is not supported.
Write a backup as a tar:
Corresponding restore:
To change the compression method, the correct file suffix should be appended to the backup name. I.E to compress the tar archive using gzip:
The supported compression file suffixes are tar.gz, .tgz tar.bz2, tar.lzma, .tar.zst, .tzst and .tar.xz.
Check the status of backups
The backup command returns an id and status, and that id can be used to get the status of the backup.  This is very useful to check the progress of long ASYNC backups.  The example below shows a failure that happened when trying to overwrite an existing backup file:
Along with system.backups table, all backup and restore operations are also tracked in the system log table backup_log:
Configuring BACKUP/RESTORE to use an S3 Endpoint
To write backups to an S3 bucket you need three pieces of information:
- S3 endpoint,
for example https://mars-doc-test.s3.amazonaws.com/backup-S3/
- Access key ID,
for example ABC123
- Secret access key,
for example Abc+123
Creating an S3 bucket is covered in Use S3 Object Storage as a ClickHouse disk, just come back to this doc after saving the policy, there is no need to configure ClickHouse to use the S3 bucket.
The destination for a backup will be specified like this:
Create a base (initial) backup
Incremental backups require a base backup to start from, this example will be used
later as the base backup.  The first parameter of the S3 destination is the S3 endpoint followed by the directory within the bucket to use for this backup.  In this example the directory is named my_backup.
Add more data
Incremental backups are populated with the difference between the base backup and the current content of the table being backed up. Add more data before taking the incremental backup:
Take an incremental backup
This backup command is similar to the base backup, but adds SETTINGS base_backup and the location of the base backup.  Note that the destination for the incremental backup is not the same directory as the base, it is the same endpoint with a different target directory within the bucket.  The base backup is in my_backup, and the incremental will be written to my_incremental:
Restore from the incremental backup
This command restores the incremental backup into a new table, data3.  Note that when an incremental backup is restored, the base backup is also included.  Specify only the incremental backup when restoring:
Verify the count
There were two inserts into the original table data, one with 1,000 rows and one with 100 rows, for a total of 1,100. Verify that the restored table has 1,100 rows:
Verify the content
This compares the content of the original table, data with the restored table data3:
BACKUP/RESTORE using an S3 disk
It is also possible to BACKUP/RESTORE to S3 by configuring an S3 disk in the ClickHouse storage configuration.  Configure the disk like this by adding a file to /etc/clickhouse-server/config.d:
And then BACKUP/RESTORE as usual:
But keep in mind that:
- This disk should not be used for MergeTreeitself, only forBACKUP/RESTORE
- If your tables are backed by S3 storage, then it will try to use the S3 server-side copy with CopyObjectcalls to copy parts to the destination bucket using its credentials. If an authentication error occurs, it will fallback to the copy with buffer method (download parts and upload them) which is very inefficient. In this case, you may want to ensure you havereadpermissions on the source bucket with the credentials of the destination bucket.
Using named collections
Named collections can be used for BACKUP/RESTORE parameters. See here for an example.
Alternatives
ClickHouse stores data on disk, and there are many ways to backup disks. These are some alternatives that have been used in the past, and that may fit in well in your environment.
Duplicating source data somewhere else
Often data that is ingested into ClickHouse is delivered through some sort of persistent queue, such as Apache Kafka. In this case it is possible to configure an additional set of subscribers that will read the same data stream while it is being written to ClickHouse and store it in cold storage somewhere. Most companies already have some default recommended cold storage, which could be an object store or a distributed filesystem like HDFS.
Filesystem snapshots
Some local filesystems provide snapshot functionality (for example, ZFS), but they might not be the best choice for serving live queries. A possible solution is to create additional replicas with this kind of filesystem and exclude them from the Distributed tables that are used for SELECT queries. Snapshots on such replicas will be out of reach of any queries that modify data. As a bonus, these replicas might have special hardware configurations with more disks attached per server, which would be cost-effective.
For smaller volumes of data, a simple INSERT INTO ... SELECT ... to remote tables might work as well.
Manipulations with parts
ClickHouse allows using the ALTER TABLE ... FREEZE PARTITION ... query to create a local copy of table partitions. This is implemented using hardlinks to the /var/lib/clickhouse/shadow/ folder, so it usually does not consume extra disk space for old data. The created copies of files are not handled by ClickHouse server, so you can just leave them there: you will have a simple backup that does not require any additional external system, but it will still be prone to hardware issues. For this reason, it's better to remotely copy them to another location and then remove the local copies. Distributed filesystems and object stores are still a good options for this, but normal attached file servers with a large enough capacity might work as well (in this case the transfer will occur via the network filesystem or maybe rsync).
Data can be restored from backup using the ALTER TABLE ... ATTACH PARTITION ...
For more information about queries related to partition manipulations, see the ALTER documentation.
A third-party tool is available to automate this approach: clickhouse-backup.
Settings to disallow concurrent backup/restore
To disallow concurrent backup/restore, you can use these settings respectively.
The default value for both is true, so by default concurrent backup/restores are allowed. When these settings are false on a cluster, only 1 backup/restore is allowed to run on a cluster at a time.
Configuring BACKUP/RESTORE to use an AzureBlobStorage Endpoint
To write backups to an AzureBlobStorage container you need the following pieces of information:
- AzureBlobStorage endpoint connection string / url,
- Container,
- Path,
- Account name (if url is specified)
- Account Key (if url is specified)
The destination for a backup will be specified like this:
Backup up system tables
System tables can also be included in your backup and restore workflows, but their inclusion depends on your specific use case.
Backing up log tables
System tables that store historic data, such as those with a _log suffix (e.g., query_log, part_log), can be backed up and restored like any other table. If your use case relies on analyzing historic data—for example, using query_log to track query performance or debug issues—it's recommended to include these tables in your backup strategy. However, if historic data from these tables is not required, they can be excluded to save backup storage space.
Backing up access management tables
System tables related to access management, such as users, roles, row_policies, settings_profiles, and quotas, receive special treatment during backup and restore operations. When these tables are included in a backup, their content is exported to a special accessXX.txt file, which encapsulates the equivalent SQL statements for creating and configuring the access entities. Upon restoration, the restore process interprets these files and re-applies the SQL commands to recreate the users, roles, and other configurations.
This feature ensures that the access control configuration of a ClickHouse cluster can be backed up and restored as part of the cluster's overall setup.
Note: This functionality only works for configurations managed through SQL commands (referred to as "SQL-driven Access Control and Account Management"). Access configurations defined in ClickHouse server configuration files (e.g. users.xml) are not included in backups and cannot be restored through this method.
