Legacy configuration for high availability

This page describes the legacy configuration for a MySQL instance for high availability (HA).

In a legacy HA configuration, a Cloud SQL for MySQL instance uses a failover replica to add high availability to the instance. This feature isn't available in Google Cloud console. The recommended configuration doesn't use failover replicas. Instead, the current high availability configuration uses Google regional persistent disks, which synchronously replicate data at the block-level between two zones in a region.

For more information about the current high availability configuration, see Overview of the High Availability Configuration.

Update an instance from legacy to current high availability

To update your instance from the legacy to the current high availability configuration, do the following:

  1. Update your instance to the current high availability configuration.

    1. Delete the failover replica for the MySQL instance you want to update. For more information, see Disable high availability on an instance.
    2. Configure the primary instance to use the current version of high availability. For more information, see Configure an existing instance for high availability.

    As another option, use Database Migration Service to migrate to an instance that uses the current high availability configuration.

  2. Create a read replica instance to offload any read workloads that you don't want to perform on the primary instance.

Initiate failover

Testing failover is optional, but is recommended so that you can see how your application responds in the event of a failover.

To learn more about failovers, see the Failover overview.

gcloud

Initiate the failover:

gcloud sql instances failover PRIMARY_INSTANCE_NAME

curl

  1. Describe the primary instance to get the value of the settingsVersion field.
    gcloud auth login
    ACCESS_TOKEN="$(gcloud auth print-access-token)"
    curl --header "Authorization: Bearer ${ACCESS_TOKEN}" \
         -X GET \
         https://www.googleapis.com/sql/v1beta4/projects/PROJECT-ID/instances/PRIMARY_INSTANCE_NAME
  2. Initiate the failover:
    gcloud auth login
    ACCESS_TOKEN="$(gcloud auth print-access-token)"
    curl --header "Authorization: Bearer ${ACCESS_TOKEN}" \
         --header 'Content-Type: application/json' \
         --data '{"failoverContext":{"settingsVersion":"SETTINGS_VERSION"}}' \
         -X POST \
         https://www.googleapis.com/sql/v1beta4/projects/PROJECT-ID/instances/PRIMARY_INSTANCE_NAME/failover

The instance fails over and is not available to serve data for a few minutes.

Legacy configuration: Create an alert for replication lag

The time required for a failover operation depends on the amount of replication lag when the failover is initiated. You can use Cloud Monitoring in the Google Cloud console to alert you when replication lag exceeds a threshold.

For more information about replication lag, search for "seconds_behind_master" on the SHOW SLAVE STATUS Syntax page in the MySQL documentation.

For more information about Cloud Monitoring, see the Cloud Monitoring documentation.

Legacy configuration: Set an alert for a specific failover replica

  1. In the navigation panel of the Google Cloud console, select Monitoring, and then select Alerting.
  2. Click Create Alerting Policy.
  3. Enter a descriptive name for your alert.
  4. Select Metric Threshold and click Next to open the Target tab.
  5. For Resource Type, select Cloud SQL.
  6. For Applies To, select Single, then select your failover replica.
  7. Click Next to open the Configuration tab.
  8. Enter the following values:

    Field Value
    If Metric Seconds Behind Master
    Condition above
    Thresholds 120 (or whatever value is appropriate for your environment)
    For 3 minutes

  9. Select your Notification methods, and click Save Condition.

Legacy configuration: Set an alert for a group of failover replicas

If you plan to create multiple failover replicas in the same project, it could be easier to set the alert for the entire group, rather than on each failover replica individually. To create a group for monitoring, use a suffix for the failover replicas' names, such as "-failover". Make sure you don't use this suffix for any other types of Cloud SQL instances.

Create your failover replica group:

  1. In the Google Cloud console, go to the Monitoring page.

    Go to Monitoring

  2. From the upper menu bar, select Groups > Create....
  3. Enter a descriptive name for your group.
  4. Leave Name and Contains selected, and enter your name substring.
  5. Click Save Group. The summary page for the new group opens.
  6. Confirm that the expected instances are included in the group.

Create the alert for the failover replica group:

  1. In the navigation panel of the Google Cloud console, select Monitoring, and then select Alerting.
  2. Click Create Alerting Policy.
  3. Enter a descriptive name for your group alert.
  4. Select Metric Threshold and click Next to open the Target tab.
  5. For Resource Type, select Cloud SQL.
  6. For Applies To, select Group, then select your failover group.
  7. Leave Any Member Violates selected and click Next to open the Configuration tab.
  8. Enter the following values:

    Field Value
    If Metric Seconds Behind Master
    Condition above
    Thresholds 120 (or whatever value is appropriate for your environment)
    For 3 minutes

  9. Select your desired Notification methods, and click Save Condition.

Legacy configuration: Disable high availability on an instance

You need to delete the failover replica instance to remove high availability from the primary instance.

Before you perform this procedure, make sure there are no operations currently running on the primary instance.

To disable high availability:

Console

  1. In the Google Cloud console, go to the Cloud SQL Instances page.

    Go to Cloud SQL Instances

  2. Select the failover instance associated with the instance you want to disable high availability on.
  3. On the Instance details page, click Delete.
  4. In the Delete Replica window, retype the name of failover instance.
  5. Click Delete. The configuration for the original instance changes to zonal.

gcloud

For reference information, see gcloud sql instances delete.
gcloud sql instances delete FAILOVER_REPLICA_NAME

curl

The following request uses the instances:delete method to delete the instance.
gcloud auth login
ACCESS_TOKEN="$(gcloud auth print-access-token)"
curl --header "Authorization: Bearer ${ACCESS_TOKEN}" \
     --header 'Content-Type: application/json'\
      -X DELETE\
https://www.googleapis.com/sql/v1beta4/projects/PROJECT-ID/instances/INSTANCE_NAME

What's next