This page describes how to protect Cloud SQL instances from accidental deletion.
Overview
Instance deletion protection enables you to prevent the accidental removal of existing and new instances. Using instance deletion protection, you can safeguard instances that are important to your applications and services.
You can set the deletion protection option when you create an instance. Additionally, you can set this option on an existing instance. In both cases, deletion is prevented at the instance level. By default, the deletion protection option is disabled unless you use the Google Cloud console or Terraform to create an instance.
When you clone an instance, the new instance receives the deletion protection option (enabled or disabled) from the source instance.
Planning for deletion protection
If you are planning to create an instance, decide whether you want to protect the new instance from accidental deletion. For example, a critical instance should be protected in this way.
Also consider whether there are existing instances you want to protect from accidental deletion. If you have multiple instances to protect, set the option on each instance.
Considering deletion protection for read replicas
When you create a read replica, that read replica doesn't get a deletion protection setting from the primary instance; this setting remains independent. However, you can enable deletion protection on a new or existing read replica.
For Cloud SQL read replicas, the deletion protection option works the same way as it does for Cloud SQL instances.
Confirming the necessary permissions or roles
To set the deletion protection option, the Cloud SQL instance's service account must have certain permissions or IAM roles.
Permissions or roles for creating an instance
As in the case of related operations, the deletion protection option requires
the cloudsql.instances.create permission or the cloudsql.admin role. Thus,
when you create an instance, no extra permissions are needed to enable deletion
protection.
Permissions or roles for editing an instance
As in the case of related operations, deletion protection changes require the
cloudsql.instances.update permission or the cloudsql.editor role. Thus, when
you edit an instance for deletion protection, no extra permissions are needed.
Planning for instance deletion
If you are planning to delete an instance, first do the following:
- Confirm that it is safe to delete the instance
- Confirm that deletion protection is disabled; if necessary, edit the instance to disable deletion protection
Limitations of deletion protection
Deletion protection on an instance does not prevent:
- Stopping the instance
- Restarting the instance
- Editing the instance
- Deleting a backup
- Suspending the instance due to billing issues
- Deleting the suspended instance due to billing issues
- Deleting the instance due to a project deletion
Setting deletion protection on a new instance
The following are the ways to set the deletion protection option. By default, the deletion protection option is disabled unless you use the Google Cloud console or Terraform to create an instance.
If deletion protection is enabled, an attempt to delete the instance fails.
Console
- Follow the steps to begin creating an Instance.
- Under Customize your instance, click the Show configuration options drop down arrow.
- Under Data protection, confirm that the Enable deletion protection checkbox is checked.
- As needed for your instance, select other configuration options.
- Click Create Instance.
gcloud
To set deletion protection during instance creation, use a command similar to the following:
gcloud sql instances create [INSTANCE_NAME] \ --deletion-protection
REST v1
To set deletion protection during instance creation, specify
true in the deletionProtection field.
Before using any of the request data, make the following replacements:
- project-id: Your project ID
- instance-id: Desired instance ID
- database-version: The database version
- region: desired region
- machine-type: desired machine type
HTTP method and URL:
POST https://sqladmin.googleapis.com/v1/projects/project-id/instances
Request JSON body:
{
  "name": "instance-id",
  "region": "region",
  "databaseVersion": "database-version",
  "settings": {
    "tier": "machine-type",
    "deletionProtectionEnabled": true
  }
}
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{
  "kind": "sql#operation",
  "targetLink": "https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id",
  "status": "PENDING",
  "user": "user@example.com",
  "insertTime": "2022-05-24T15:34:10.929Z",
  "operationType": "CREATE",
  "name": "operation-id",
  "targetId": "instance-id",
  "selfLink": "https://sqladmin.googleapis.com/v1/projects/project-id/operations/operation-id",
  "targetProject": "project-id"
}
REST v1beta4
To set deletion protection during instance creation, specify
true in the deletionProtection field.
Before using any of the request data, make the following replacements:
- project-id: Your project ID
- instance-id: Desired instance ID
- database-version: The database version
- region: desired region
- machine-type: desired machine type
HTTP method and URL:
POST https://sqladmin.googleapis.com/v1beta4/projects/project-id/instances
Request JSON body:
{
  "name": "instance-id",
  "region": "region",
  "databaseVersion": "database-version",
  "settings": {
    "tier": "machine-type",
    "deletionProtectionEnabled": true
  }
}
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{
  "kind": "sql#operation",
  "targetLink": "https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id",
  "status": "PENDING",
  "user": "user@example.com",
  "insertTime": "2022-05-26T15:37:10.929Z",
  "operationType": "CREATE",
  "name": "operation-id",
  "targetId": "instance-id",
  "selfLink": "https://sqladmin.googleapis.com/v1/projects/project-id/operations/operation-id",
  "targetProject": "project-id"
}
Setting or removing deletion protection on an existing instance
The following are the ways to edit an instance for deletion protection. If you enable the option, a subsequent attempt to delete the instance fails.
Console
- Follow the steps to begin editing an Instance.
- After you click Edit, find the Customize your instance section.
- Under Data protection, check or uncheck the Enable deletion protection checkbox.
- As needed for your instance, edit other configuration options.
- Click Save.
gcloud
To enable deletion protection when you update an instance, use a command similar to the following:
gcloud sql instances patch [INSTANCE_NAME] \ --deletion-protection
To disable deletion protection when you update an instance, use a command similar to the following:
gcloud sql instances patch [INSTANCE_NAME] \ --no-deletion-protection
REST v1
To set deletion protection when you update an instance, specify
true in the deletionProtection field. To remove
deletion protection, specify false in that field.
Before using any of the request data, make the following replacements:
- project-id: Your project ID
- instance-id: Desired instance ID
HTTP method and URL:
PATCH https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id
Request JSON body:
{
  "settings": {
    "deletionProtectionEnabled": true
  }
}
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{
  "kind": "sql#operation",
  "targetLink": "https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id",
  "status": "PENDING",
  "user": "user@example.com",
  "insertTime": "2022-06-1T03:42:12.281Z",
  "operationType": "CREATE",
  "name": "operation-id",
  "targetId": "instance-id",
  "selfLink": "https://sqladmin.googleapis.com/v1/projects/project-id/operations/operation-id",
  "targetProject": "project-id"
}
REST v1beta4
To set deletion protection when you update an instance, specify
true in the deletionProtection field. To remove
deletion protection, specify false in that field.
Before using any of the request data, make the following replacements:
- project-id: Your project ID
- instance-id: Desired instance ID
HTTP method and URL:
PATCH https://sqladmin.googleapis.com/v1beta4/projects/project-id/instances/instance-id
Request JSON body:
{
  "settings": {
    "deletionProtectionEnabled": true
  }
}
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
{
  "kind": "sql#operation",
  "targetLink": "https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id",
  "status": "PENDING",
  "user": "user@example.com",
  "insertTime": "2022-06-1T03:32:12.281Z",
  "operationType": "UPDATE",
  "name": "operation-id",
  "targetId": "instance-id",
  "selfLink": "https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/operations/operation-id",
  "targetProject": "project-id"
}