This page describes how to use advanced disaster recovery (DR). Advanced DR provides two main capabilities:
- Replica failover lets you fail over your primary instance to the DR replica immediately in the event of a region failure. For Cloud SQL for SQL Server, the DR replica is a cascadable replica.
- Switchover lets you reverse the roles of the primary instance and a DR replica with zero data loss. You can use switchover to restore a deployment to its original deployment state after replica failover, or you can use switchover to test DR.
Advanced DR is supported only on Cloud SQL Enterprise Plus edition instances.
Before you begin
If you plan to use the Google Cloud SDK, then you must use version 502.0.0 or
later. To check the version of the
Google Cloud SDK, run gcloud --version. To update
the Google Cloud SDK, run gcloud components update.
To install the Google Cloud SDK, see Install the gcloud CLI.
Create a DR replica
Before you use advanced DR, create a cascadable replica of the primary instance in a different region than the primary instance.
Perform a switchover
After you've created a DR replica, you can perform the switchover operation. However, as a best practice, avoid performing the switchover operation under the following circumstances:
- The primary instance is being actively used.
- Admin operations are in progress, such as automated backup or the enablement or disablement of high availability (HA).
To avoid a timeout, consider performing switchover when the transaction volume is low.
When switchover completes, the operation takes a backup of the new primary instance (the former DR replica) as soon as the new primary instance is promoted. This backup can take between 5 and 15 minutes to complete depending on the disk size. After this backup is complete, if you want to use PITR on the promoted instance, then you must manually enable PITR. For more information about the considerations of using PITR with advanced DR, see Use PITR with advanced DR.
After the switchover operation is complete, you'll notice that the direction of replication is reversed.
After your old primary instance is reconfigured as a read replica, the DNS write endpoint, which previously resolved to the old primary instance, resolves to the new primary instance.
Before you begin
Before you perform the switchover operation, do the following:
- If you haven't done so already, create a DR replica.
- Verify that the primary instance and the DR replica are online.
- If you're using a DNS write endpoint, then verify that the SSL configuration for the primary instance and the DR replica are the same. For example, if the DR replica is configured to enforce SSL encryption, but the primary instance allows unencrypted connections, then clients won't be able to connect to the new primary instance after the switchover operation completes.
- Take an on-demand backup of the primary instance. This backup is a precaution in case you need to recover from any unexpected failures.
Perform the switchover operation
gcloud
To perform the switchover operation, run the following command:
gcloud sql instances switchover REPLICA_NAME
Replace the following variables:
- REPLICA_NAME: the name of the DR replica that you want the primary instance to switch roles with.
Terraform
To begin the switchover operation, use a Terraform resource. To make the DR replica the new primary instance, use the first sample. The sample contains comments for the Terraform configuration changes you need to make to switch the primary instance and the DR replica.
After you make your changes, update the primary and DR replica by
  running terraform plan. Verify that the output includes
  Plan: 0 to add, 1 to change, 0 to destroy. To perform the
  switchover, run terraform apply.
At this point, the original primary is a replica of the new primary instance. However, that change isn't reflected in your Terraform state automatically. To make the original primary instance a replica of the new primary instance in your Terraform state, use the second sample. The second sample provides comments that describe the changes you need to make after running the first sample.
If your Terraform state is updated successfully,
    then when you run terraform plan against the second sample, a message similar to the following appears:
No changes. Your infrastructure matches the configuration.
If you run terraform apply, then you receive a
   message similar to the following:
Resources: 0 added, 0 changed, 0 destroyed.
REST v1
Before using any of the request data, make the following replacements:
- PROJECT_ID: the ID or project number of the Google Cloud project of the primary instance and the DR replica.
- REPLICA_NAME: the name of the DR replica.
HTTP method and URL:
POST https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/REPLICA_NAME/switchover
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
REST v1beta4
Before using any of the request data, make the following replacements:
- PROJECT_ID: the ID or project number of the Google Cloud project of the primary instance and the DR replica.
- REPLICA_NAME: the name of the DR replica.
HTTP method and URL:
POST https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/REPLICA_NAME/switchover
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
Perform DR by invoking a replica failover
In the event of region failure or a disaster, you can perform DR by invoking a replica failover operation to your designated DR replica. To perform a replica failover, you promote the DR replica. In contrast with switchover, the promotion of the DR replica is immediate.
Since the DR replica assumes the role of the primary instance immediately, it's possible that the replica doesn't have all of the data from the old primary instance due to replication lag. For this reason, a replica failover can incur data loss.
As part of the promotion process, replica failover takes a backup of the new primary instance (the former DR replica) right after the DR replica becomes the new primary instance. After this backup is complete, point-in-time-recovery (PITR) is fully enabled on the new primary instance. This backup can take between 5 and 15 minutes to complete depending on the disk size of the new (and old) primary instance. During this backup period, PITR isn't available.
When the old primary instance comes back online, the replica failover process takes a backup. After this backup is taken, the old primary instance is recreated as a read replica of the new primary instance.
For more information about the considerations of using PITR with advanced DR, see Use PITR with advanced DR.
After you invoke the replica failover operation, the DNS write endpoint, which previously resolved to the old primary instance, resolves to the new primary instance.
Before you begin
Before you can perform a replica failover, do the following:
- If you haven't done so already, then create a DR replica.
- Make sure the DR replica is online and healthy.
Perform the replica failover operation
gcloud
To invoke a replica failover to the DR replica, use the following command:
gcloud sql instances promote-replica \ REPLICA_NAME --failover
Replace the following variable:
- REPLICA_NAME: the name of the DR replica
REST v1
Before using any of the request data, make the following replacements:
- PROJECT_ID: the ID or project number of the Google Cloud project of the primary instance and DR replica.
- REPLICA_NAME: the name of the DR replica.
- ENABLE_REPLICA_FAILOVER: set to trueto use replica failover. If you set tofalse, then the API uses the regularpromoteReplicamethod without replica failover.
HTTP method and URL:
POST https://sqladmin.googleapis.com/v1/projects/PROJECT_ID/instances/REPLICA_NAME/promoteReplica?failover=ENABLE_REPLICA_FAILOVER
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
REST v1beta4
Before using any of the request data, make the following replacements:
- PROJECT_ID: the ID or project number of the Google Cloud project of the primary instance and DR replica.
- REPLICA_NAME: the name of the DR replica.
- ENABLE_REPLICA_FAILOVER: set to trueto use replica failover. If you set tofalse, then the API uses the regularpromoteReplicamethod without replica failover.
HTTP method and URL:
POST https://sqladmin.googleapis.com/sql/v1beta4/projects/PROJECT_ID/instances/REPLICA_NAME/promoteReplica?failover=ENABLE_REPLICA_FAILOVER
To send your request, expand one of these options:
You should receive a JSON response similar to the following:
Check the status of a replica failover
Replica failover occurs in two phases. The first phase is the promotion of the DR replica. The second phase is the recreation of the old primary instance as a read replica.
To check the status of replica failover, check the status of each phase.
- Check the status of the first phase. - Console- To check if the DR replica has been promoted to a standalone instance, do the following: - 
In the Google Cloud console, go to the Cloud SQL Instances page. 
- Find the name of the DR replica that you promoted.
- Verify that SQL Server VERSION appears in the Type column for the new primary instance.
 - gcloudYou can check the status by running the following command:- gcloud sql instances describe DR_REPLICA_NAME - Replace the following variable: - DR_REPLICA_NAME: the name of the promoted DR replica
 - In the output, check that the following field appears and the replica has become a standalone Cloud SQL primary instance: - instanceType: CLOUD_SQL_INSTANCE 
- 
- To verify the completion of the second phase, check the operations log on the instance for the message - RECONFIGURE_OLD_PRIMARY.- The appearance of this message depends on when the old primary instance returns online, which can take minutes or days in the event of a disaster. - For more information on how to check the operations logs on an instance, see View instance logs. 
Use PITR with advanced DR
Whether a switchover or replica failover, if the DR replica is promoted to a primary instance, and you want to use PITR on the promoted instance, you must manually enable PITR.
After PITR is enabled, the backup configuration and transaction log retention policies apply. If you don't specify values for these settings, the default value of 14 days applies.
For more information, see Use PITR.
After PITR is enabled on the new primary instance, you can restore the instance to any point in time during which it is an active primary instance.
Split-brain during replica failover
It's possible that split-brain occurs when the primary instance continues to accept writes while a replica is promoted using replica failover. After the replica is promoted, when the old primary instance is available again, it is rebuilt as a replica of the promoted instance and a final backup is made. This backup can be used to recover any split-brain data that was not written to the promoted replica.
Deletion of backups and transaction logs on replicas
If a primary instance that was enabled with PITR and backups becomes a read replica, then the last backup and PITR retention policy from its time as a primary instance is preserved and applied during its time as a replica. Even though the new primary instance is not taking backups, the old backups and transaction logs used for PITR are deleted on the read replica according to the last configured policy.
For example, if the instance is configured to have daily automated backups and keep 7 backups with 7 days of PITR logs, then when this instance becomes a read replica, anything older than 7 days is deleted once a day.
If you need to delete backups sooner, then you can remove backups manually. For more information, see Delete a backup.
Recommendations for VPC Service Controls and advanced DR
If you use VPC Service Controls, then make sure that your service perimeters allow necessary communications for all recovery operations such as point-in-time recovery (PITR) operations, especially when you use CMEK with keys in a different project.
Advanced DR operations, like switchover and replica failover, can enable or reconfigure features like PITR, which can be blocked by VPC Service Controls if the service perimeters aren't configured correctly for CMEK and cross-project key access.
- Keep KMS key project in same perimeter as instance: as a best practice, include the project containing the KMS key in the same VPC Service Controls perimeter as your Cloud SQL instances.
- Use a perimeter bridge: as a secondary (less recommended) option, you can use a perimeter bridge to connect projects in different perimeters.
- Test: use VPC Service Controls dry run mode to test your DR procedures (like switchover) and identify potential VPC Service Controls violations without enforcement.
For more information, see Configure VPC Service Controls.
Limitations
- You can't designate a Cloud SQL Enterprise Plus edition read replica instance as DR replica if the primary instance stores its transaction logs for point-in-time recovery (PITR) on disk. To check where an instance stores its logs for PITR, see Check the storage location of transaction logs used for PITR. 
- You can't designate an external replica as a DR replica. 
- Terraform isn't supported for replica failover operations. 
- You can't use the Google Cloud console to perform replica failover or switchover operations.
Troubleshoot
| Issue | Troubleshooting | 
|---|---|
| Switchover operation has failed. | 
 | 
| Switchover operation has failed and the primary instance is stuck in read-only mode. | Perform a database restart to bring the primary instance back to write mode. | 
| Switchover operation has completed, but the Google Cloud console doesn't show the new reversed roles for the instances. | Refresh your browser to show the updated topology. | 
| Replica failover operation has failed. | 
 | 
What's next
- View all the Google Cloud services available in locations worldwide.
- Read about database observability
- Monitor Cloud SQL instances