title | summary | toc |
---|---|---|
Back up and Restore Data |
Learn how to back up and restore a CockroachDB database. |
true |
Because CockroachDB is designed with high fault tolerance, backups are primarily needed for disaster recovery (i.e., if your cluster loses a majority of its nodes). Isolated issues (such as small-scale node outages) do not require any intervention. However, as an operational best practice, we recommend taking regular backups of your data.
Based on your license type, CockroachDB offers two methods to back up and restore your cluster's data: Enterprise and Core.
If you have an Enterprise license, you can use the BACKUP
statement to efficiently back up your cluster's schemas and data to popular cloud services such as AWS S3, Google Cloud Storage, or NFS, and the RESTORE
statement to efficiently restore schema and data as necessary.
In most cases, it's recommended to use the BACKUP
command to take full nightly backups of each database in your cluster:
{% include copy-clipboard.html %}
> BACKUP DATABASE <database_name> TO '<full_backup_location>';
If it's ever necessary, you can then use the RESTORE
command to restore a database:
{% include copy-clipboard.html %}
> RESTORE DATABASE <database_name> FROM '<full_backup_location>';
If a database increases to a size where it is no longer feasible to take nightly full backups, you might want to consider taking periodic full backups (e.g., weekly) with nightly incremental backups. Incremental backups are storage efficient and faster than full backups for larger databases.
Periodically run the BACKUP
command to take a full backup of your database:
{% include copy-clipboard.html %}
> BACKUP DATABASE <database_name> TO '<full_backup_location>';
Then create nightly incremental backups based off of the full backups you've already created.
{% include copy-clipboard.html %}
> BACKUP DATABASE <database_name> TO 'incremental_backup_location'
INCREMENTAL FROM '<full_backup_location>', '<list_of_previous_incremental_backup_location>';
If it's ever necessary, you can then use the RESTORE
command to restore a database:
{% include copy-clipboard.html %}
> RESTORE <database_name> FROM '<full_backup_location>', '<list_of_previous_incremental_backup_locations>';
{{site.data.alerts.callout_success}} Restoring from incremental backups requires previous full and incremental backups. {{site.data.alerts.end}}
You can automate your backups using scripts and your preferred method of automation, such as cron jobs.
For your reference, we have created this [sample backup script](https://raw.githubusercontent.com/cockroachdb/docs/master/_includes/{{ page.version.version }}/prod-deployment/backup.sh) that you can customize to automate your backups.
In the sample script, configure the day of the week for which you want to create full backups. Running the script daily will create a full backup on the configured day, and on other days, it'll create incremental backups. The script tracks the recently created backups in a separate file titled backup.txt
and uses this file as a base for the subsequent incremental backups.
-
Download the [sample backup script](https://raw.githubusercontent.com/cockroachdb/docs/master/_includes/{{ page.version.version }}/prod-deployment/backup.sh):
{% include copy-clipboard.html %}
$ wget -qO- https://raw.githubusercontent.com/cockroachdb/docs/master/_includes/{{ page.version.version }}/prod-deployment/backup.sh
Alternatively, you can create the file yourself and copy the script into it:
{% include copy-clipboard.html %}
#!/bin/bash set -euo pipefail # This script creates full backups when run on the configured # day of the week and incremental backups when run on other days, and tracks # recently created backups in a file to pass as the base for incremental backups. full_day="<day_of_the_week>" # Must match (including case) the output of `LC_ALL=C date +%A`. what="DATABASE <database_name>" # The name of the database you want to back up. base="<storage_URL>/backups" # The URL where you want to store the backup. extra="<storage_parameters>" # Any additional parameters that need to be appended to the BACKUP URI (e.g., AWS key params). recent=recent_backups.txt # File in which recent backups are tracked. backup_parameters=<additional backup parameters> # e.g., "WITH revision_history" # Customize the `cockroach sql` command with `--host`, `--certs-dir` or `--insecure`, and additional flags as needed to connect to the SQL client. runsql() { cockroach sql --insecure -e "$1"; } destination="${base}/$(date +"%Y%m%d-%H%M")${extra}" prev= while read -r line; do [[ "$prev" ]] && prev+=", " prev+="'$line'" done < "$recent" if [[ "$(LC_ALL=C date +%A)" = "$full_day" || ! "$prev" ]]; then runsql "BACKUP $what TO '$destination' AS OF SYSTEM TIME '-1m' $backup_parameters" echo "$destination" > "$recent" else destination="${base}/$(date +"%Y%m%d-%H%M")-inc${extra}" runsql "BACKUP $what TO '$destination' AS OF SYSTEM TIME '-1m' INCREMENTAL FROM $prev $backup_parameters" echo "$destination" >> "$recent" fi echo "backed up to ${destination}"
-
In the sample backup script, customize the values for the following variables:
Variable Description full_day
The day of the week on which you want to take a full backup. what
The name of the database you want to back up (i.e., create backups of all tables and views in the database). base
The URL where you want to store the backup.
URL format:[scheme]://[host]/[path]
For information about the components of the URL, see Backup File URLs.extra
The parameters required for the storage.
Parameters format:?[parameters]
For information about the storage parameters, see Backup File URLs.backup_parameters
Additional backup parameters you might want to specify. Also customize the
cockroach sql
command with--host
,--certs-dir
or--insecure
, and additional flags as required. -
Change the file permissions to make the script executable:
{% include copy-clipboard.html %}
$ chmod +x backup.sh
-
Run the backup script:
{% include copy-clipboard.html %}
$ ./backup.sh
{{site.data.alerts.callout_info}}
If you miss an incremental backup, delete the recent_backups.txt
file and run the script. It'll take a full backup for that day and incremental backups for subsequent days.
{{site.data.alerts.end}}
In case you do not have an Enterprise license, you can perform a Core backup. Run the cockroach dump
command to dump all the tables in the database to a new file (backup.sql
in the following example):
{% include copy-clipboard.html %}
$ cockroach dump <database_name> <flags> > backup.sql
To restore a database from a Core backup, use the cockroach sql
command to execute the statements in the backup file:
{% include copy-clipboard.html %}
$ cockroach sql --database=[database name] < backup.sql
{{site.data.alerts.callout_success}} If you created a backup from another database and want to import it into CockroachDB, see Import data. {{site.data.alerts.end}}