Managed Backups in CockroachDB Advanced Clusters

On this page Carat arrow pointing down

Managed backups are automated backups of CockroachDB Cloud clusters that are stored by Cockroach Labs in cloud storage. By default, Cockroach Labs takes and retains managed backups in all Cloud clusters. In Standard and Advanced clusters, you can adjust the default managed backup settings to meet your organization's disaster recovery requirements.

This page describes managed backups in Advanced clusters. You can configure the following:

Note:

In addition to managed backups, you can take manual backups to your own storage bucket with self-managed backups. Refer to the Take and Restore Self-Managed Backups page.

Managed backup settings

Note:

Configurable managed backup settings are available in all supported versions of CockroachDB on Advanced clusters.

Advanced clusters take a combination of full and incremental backups in order to meet the set frequency. The type of managed backup the cluster takes is not configurable. Each incremental backup is dependent on the last full backup, which has an effect on the managed backups that you can restore in the set retention period.

Full backups in the cluster will be deleted when they reach the set retention period. At this point, any incremental backups dependent on the deleted full backup will also be deleted. The Cloud Console will not list any backups that are beyond the set retention period, or incremental backups that cannot be restored.

For instructions on how to view and configure managed backup settings, use one of the following:

Following a change to the backup frequency or retention setting, the cluster will take a full backup immediately, which may impact CPU usage on the cluster. If you are disabling managed backups, the cluster will not take a backup following the change.

Frequency

You can configure how frequently Cockroach Labs takes backups, which will determine the cluster's RPO.

You can set backup frequency to one of the following options:

  • 5 minutes
  • 10 minutes
  • 15 minutes
  • 30 minutes
  • 1 hour (default)
  • 4 hours
  • 24 hours

Retention

You can set your retention duration once. After you have adjusted the retention, the duration will only apply to new backups. The available retention options are:

  • 2 days
  • 7 days
  • 30 days (default)
  • 90 days
  • 365 days

You'll be able to modify the retention setting once for a cluster. To modify the setting again, contact the Cockroach Labs Support team.

When a cluster is deleted, Cockroach Labs will retain the managed backups for for the configured retention time, after which the backups will be deleted.

If a customer’s agreement with Cockroach Labs has terminated, all managed backups will be retained for a maximum of 30 days and then deleted. If a backup's retention time was set to less than 30 days, Cockroach Labs will retain the managed backups for the configured retention time, after which the backups will be deleted.

To restore a backup from a deleted cluster, you must contact the Cockroach Labs Support team.

Considerations

  • Every backup will be stored entirely in a single region, which is chosen at random from the list of cluster regions at the time of cluster creation. This region will be used indefinitely to store backups.
  • You can perform a cross-cluster restore across Advanced clusters that belong to the same organization. However, this cross-cluster restore is not supported for Standard and Basic clusters.
  • You cannot restore a backup of a multi-region database into a single-region database.
  • For details on managed backups and enabling CMEK in Advanced clusters, refer to Backup and restore operations on a cluster with CMEK.

Cloud Console

View backups

Click on Backup and Restore in the Data section of the left-side navigation to access the Backup Recovery page.

The Backups tab displays a list of your full and incremental cluster backups. Use the calendar drop-down to view all backups taken on a certain date.

For each backup, the following details display:

  • Data From: The date and time the backup was taken.
  • Status: The backup's status, In Progress or Complete.
  • Type: Whether the backup is a full or incremental backup.
  • Expires In: The remaining number of days Cockroach Labs will retain the backup.
  • Databases: The number of databases included in the backup.
  • Restore: Restore a particular cluster backup, click Restore in the corresponding row.

Databases

To view the databases included in the backup, click the number in the Databases column on the Backups tab.

For each database in the backup, the following details display:

  • The Name of the database.
  • The number of Tables in the database. If a database does not contain tables, it will not display in the Databases view.
  • Restore: To restore a database, click Restore in the corresponding row.

    To view the tables in the database, click the number in the Tables column.

Tables

To view the tables in a database, click the number in the Tables column on the Databases page for a particular backup.

For each table in the database, the Name of the table displays.

To restore a table, click Restore in the corresponding row.

Modify backup settings

Note:

Following a change to the backup frequency or retention setting, the cluster will take a full backup immediately, which may impact CPU usage on the cluster. If you are disabling managed backups, the cluster will not take a backup following the change.

Before modifying cluster backup settings, review details on backup settings for Standard and Advanced clusters.

On the Backup and Restore page, click on Settings and the Backup Settings module will open.

The Enable backups switch allows you to enable or disable backups.

To modify the frequency of backups, click on the dropdown under Schedule backups every. This will display the option to select one of the following:

  • 5 minutes
  • 10 minutes
  • 15 minutes
  • 30 minutes
  • 1 hour (default)
  • 4 hours
  • 24 hours

To modify the retention of backups, click on Retain backups for. This will display the following options to select:

  • 2 days
  • 7 days
  • 30 days (default)
  • 90 days
  • 365 days

You'll be able to modify the retention setting once for a cluster. To modify the setting again, contact the Cockroach Labs Support team.

Incomplete Backups

To view any failed or pending backups, click the Incomplete Backups tab on the Backup and Restore page.

For each incomplete backup, the following details display:

  • Started: The date and time the backup job began.
  • Duration: The amount of time the backup job ran for.
  • Status: The error code and message for failed backup jobs.
  • Description: The SQL command corresponding to the failed or pending backup job.

Restore data

Users with the Org Administrator, Cluster Operator, or Cluster Administrator roles can perform the following from the Console:

Restore an Advanced cluster

Warning:

The restore completely erases all data in the destination cluster. All cluster data is replaced with the data from the backup. The destination cluster will be unavailable while the job is in progress.

This operation is disruptive and is to be performed with caution. Use the Principle of Least Privilege (PoLP) as a golden rule when designing your system of privilege grants.

To restore a cluster:

  1. Find the cluster backup on the Backups tab.
  2. Click Restore for the cluster you want to restore.

    The Restore cluster module displays with backup details.

  3. Select the cluster to restore to. You can restore to either the same cluster or a different Advanced cluster in the same organization. Incompatible versions cannot be selected. By default, the option shows the current cluster. The dropdown displays options to restore to a different cluster.

    Select the Skip localities check box if you want to skip checking localities of a cluster before a restore when there are mismatched cluster regions between the backup's cluster and the destination cluster.

  4. Click Continue.

  5. Enter the name of the destination cluster.

  6. Once you have reviewed the restore details, click Restore.

    The Restore Jobs tab will show you the status of your restore and update when the restore job has been created successfully.

Restore a database

To restore a database:

  1. On the Backups tab, find the cluster backup containing the database you want to restore, and click the number in the corresponding Databases column.
  2. In the Databases view, click Restore for the database you want to restore.

    The Restore database module displays with backup details.

  3. In the Restore to fields:

    • Select the name of the destination cluster.
    • Type the name of the destination database.
    Note:

    Resolve any naming conflicts by using DROP or RENAME on the existing database. If you enter a unique name in the Restore to field, a new database will be created.

  4. Select any of the Dependency options to skip. You can:

    • Skip missing foreign keys, which will remove missing foreign key constraints (i.e., when the referenced table is not in the backup or is not being restored) before restoring.
    • Skip missing sequences, which will ignore sequence dependencies (i.e., the DEFAULT expression that uses the sequence).
    • Skip missing views, which will skip restoring views that cannot be restored because their dependencies are not being restored at the same time.
    • Skip localities check, which will skip checking localities of a cluster before a restore when there are mismatched cluster regions between the backup's cluster and the destination cluster.
  5. Click Continue.

  6. Once you have reviewed the restore details, click Restore.

    When the restore job has been created successfully, you will be taken to the Restore Jobs tab, which will show you the status of your restore.

When the restore is complete, be sure to set any database-specific zone configurations and, if applicable, grant privileges.

Restore a table

To restore a table:

  1. Find the cluster backup containing the table you want to restore, and click the number in the corresponding Databases column.
  2. In the Databases view, find the database containing the table you want to restore, and click the number in the corresponding Tables column.

    The Tables view displays.

  3. Click Restore for the table you want to restore.

    The Restore table module displays with backup details.

  4. In the Restore to fields:

    • Select the name of the destination cluster.
    • Type the name of the destination database. (Before restoring, ensure that you do not have an existing table with the same name.)
    Note:

    If you enter the name of an existing database, the table will be restored into that existing database. To use the name of an existing database, first resolve any naming conflicts with existing tables by using DROP or RENAME on the table. If you enter a unique name in the Restore to field, a new database will be created.

  5. Select any of the Dependency options to skip. You can:

    • Skip missing foreign keys, which will remove missing foreign key constraints (i.e., when the referenced table is not in the backup or is not being restored) before restoring.
    • Skip missing sequences, which will ignore sequence dependencies (i.e., the DEFAULT expression that uses the sequence).
    • Skip missing views, which will skip restoring views that cannot be restored because their dependencies are not being restored at the same time.
  6. Click Continue.

  7. Once you have reviewed the restore details, click Restore.

When the restore job has been created successfully, you will be taken to the Restore Jobs tab, which will show you the status of your restore.

Restore Jobs

To view the status of your restore, click on the Restore Jobs tab from the cluster Backup and Restore page.

For each restore job, the tab will display:

  • Source > Destination: The source cluster, database, or table to the destination cluster, database, or table.
  • Restore type: Whether the job is a cluster, database, table restore.
  • Backup taken on: The date the backup was originally taken.
  • Status: The status of the restore job Preparing, Running, Succeeded, Failed.
  • Restore start: The date the restore job was initiated.
  • Restore end: The date the restore job ened (whether successful or unsuccessful).
  • Job ID: The job ID of the restore job.

Cloud API

You can use the CockroachDB Cloud API to view and modify managed backup settings.

Note:

The service account associated with the secret key must have the Cluster Administrator role.

Get information on backup settings

To retrieve information about a specific cluster, make a GET request to the /v1/clusters/{cluster_id}/backups/config endpoint.

icon/buttons/copy
curl --request GET \
--url https://cockroachlabs.cloud/api/v1/clusters/{cluster_id}/backups/config \
--header 'Authorization: Bearer {secret_key}'

Set the following:

  • {cluster_id} is the unique ID of the cluster. Use this ID when making API requests. You can find the cluster ID in the cluster's Cloud Console page. Find your cluster ID in the URL of the single cluster overview page: https://cockroachlabs.cloud/cluster/{your_cluster_id}/overview. The ID should resemble f78b7feb-b6cf-4396-9d7f-494982d7d81e.
  • {secret_key} is your API key. Refer to API Access for more details.

If the request was successful, the API will return details about the managed backup settings:

{
  "enabled": true,
  "retention_days": 30,
  "frequency_minutes": 240
}
  • {enabled} shows whether managed backups are enabled or disabled.
  • {frequency_minutes} is how often the managed backup will run in minutes.
  • {retention_days} is the number of days Cockroach Labs will retain the managed backup in storage.

Modify backup settings on a cluster

Note:

Following a change to the backup frequency or retention setting, the cluster will take a full backup immediately, which may impact CPU usage on the cluster. If you are disabling managed backups, the cluster will not take a backup following the change.

Before modifying cluster backup settings, review details on backup settings for Standard and Advanced clusters.

To configure the frequency and retention of managed backups, send a PUT request to the /v1/clusters/{cluster_id}/backups/config endpoint.

icon/buttons/copy
curl --request PUT \
--url https://cockroachlabs.cloud/api/v1/clusters/{cluster_id}/backups/config \
--header 'Authorization: Bearer {secret_key}' \
--data '{"enabled": true, "frequency_minutes": 30, "retention_days": 2}'

Set the following:

  • {cluster_id} is the unique ID of the cluster. Use this ID when making API requests. You can find the cluster ID in the cluster's Cloud Console page. Find your cluster ID in the URL of the single cluster overview page: https://cockroachlabs.cloud/cluster/{your_cluster_id}/overview. The ID should resemble f78b7feb-b6cf-4396-9d7f-494982d7d81e.
  • {enabled} controls whether managed backups are enabled or disabled. If you are disabling managed backups, you cannot set backup frequency or retention. Possible values are: true, false.
  • {frequency_minutes} determines how often the managed backup will run in minutes. Possible values are: 5, 10, 15, 30, 60, 240 (4 hours), 1440 (24 hours).
  • {retention_days} sets the number of days Cockroach Labs will retain the managed backup in storage. You can change retention_days for the cluster once (whether in the Cloud API or Cloud Console). Possible values are: 2, 7, 30, 90, 365.

    If {retention_days} has previously been modified (in the Cloud API or Cloud Console), you will receive the message "cluster already has a retention policy set, open a support ticket to change it". To modify the setting again, contact the Cockroach Labs Support team.

  • {secret_key} is your API key. Refer to API Access for more details.

If the request was successful, the client will receive an empty HTTP 200 OK status response.

CockroachDB Cloud Terraform provider

You can use the CockroachDB Cloud Terraform provider to specify managed backup settings in Advanced clusters.

In your main.tf Terraform configuration file, use the backup_config attribute on the cockroach_cluster resource to modify the settings of managed backups. For example:

icon/buttons/copy
resource "cockroach_cluster" "advanced" {
  name           = "cockroach-advanced"
  cloud_provider = "GCP"
  plan           = "ADVANCED"
  dedicated = {
    storage_gib  = 15
    num_virtual_cpus = 4
  }
  regions = [
    {
      name       = "us-central1"
      node_count = 1
    }
  ]
  delete_protection = true
  backup_config = {
    enabled           = true
    frequency_minutes = 60
    retention_days    = 30
  }
}

Set the following for the backup_config attribute:

  • enabled controls whether managed backups are enabled or disabled. If you modify the retention_days setting even when managed backups are disabled, this will use the one possible change for retention_days. Possible values for the enabled setting are: true or false.
  • frequency_minutes determines how often the managed backup will run in minutes. Possible values are: 5, 10, 15, 30, 60, 240 (4 hours), 1440 (24 hours).
  • retention_days sets the number of days Cockroach Labs will retain the managed backup in storage. You can change retention_days for the cluster once (whether in Terraform, the Cloud API, or the Cloud Console). Possible values are: 2, 7, 30, 90, 365. Note that:

    • If the initial value of the retention_days attribute is the default value 30, you'll be able to modify the backup retention setting once more.
    • If the initial value is not the default, you will not be able to modify retention_days again. You can refrain from including retention_days in the Terraform configuration and instead manage the retention in the Cloud Console.

    To modify the setting again, contact the Cockroach Labs Support team. For more details on modifying retention_days, refer to the Updating Backup Retention documentation in the Terraform provider for CockroachDB Cloud Repository.


Yes No
On this page

Yes No