使用跨区域复制

本页面介绍了如何通过创建和管理次要实例来使用跨区域复制。

如需从概念上大致了解跨区域复制,请参阅跨区域复制简介

创建次要实例

创建辅助实例时,Memorystore for Valkey 会复制主实例的一些设置并将其应用于辅助实例。如需了解详情,请参阅实例设置

您可以使用Google Cloud 控制台或 Google Cloud CLI 在 Memorystore for Valkey 中创建辅助实例。

控制台

  1. 在 Google Cloud 控制台中,前往 Memorystore for Valkey 页面。

    Memorystore for Valkey

  2. 点击主实例。主实例是您要创建的辅助实例的父实例。

  3. 在侧边栏中,点击辅助实例标签页。

  4. 点击添加辅助实例

  5. 添加辅助实例窗口中,进行以下更改:

    1. 实例 ID 字段中,输入您要创建的次要实例的 ID。ID 的长度必须介于 1 到 63 个字符之间,且只能使用小写字母、数字或连字符。必须以小写字母开头,以小写字母或数字结尾,并且在其区域中是唯一的。

    2. 区域菜单中,选择您希望辅助实例所在的区域。

    3. 可用区级可用性部分,选择以下选项之一:

      • 如果您希望实例的所有分片和副本都分布在 Memorystore for Valkey 创建实例的区域中的三个可用区内,请选择多可用区选项。

        例如,如果您选择的区域为 us-central1,并选择多可用区选项,则 Memorystore for Valkey 会将实例的分片和副本分布在 us-central1-aus-central1-b
        us-central1-c 可用区中。如果发生可用区故障,实例中的节点将故障切换到副本。

      • 如果您希望实例的所有分片和副本都位于 Memorystore for Valkey 创建实例的区域中的一个可用区内,请选择单可用区选项,然后从可用区菜单中选择可用区。

        通过使用单个可用区,您可以降低网络费用。不过,如果发生可用区级故障,则不会进行故障切换。

    4. 副本菜单中,为实例选择副本数量(每个分片)。您可以有 0 个、1 个或 2 个副本。

    5. 网络菜单中,为实例选择一个网络。如需详细了解 Memorystore for Valkey 的网络,请参阅网络

  6. 点击添加辅助实例

gcloud

如需创建辅助实例,请使用 gcloud memorystore instances create 命令。

gcloud memorystore instances create INSTANCE_ID \
--project=PROJECT_ID \
--location=REGION_ID \
--cross-instance-replication-config-role=secondary \
--psc-auto-connections=network=NETWORK,projectId=PROJECT_ID \
--primary-instance=PRIMARY_INSTANCE_PATH

进行以下替换:

  • INSTANCE_ID:您要创建的次要实例的 ID。ID 必须为 1 到 63 个字符,且只能使用小写字母、数字或连字符。必须以小写字母开头,以小写字母或数字结尾,并且在其区域中必须是唯一的。
  • PROJECT_ID:您要在其中创建辅助实例的项目的 ID。这是主实例所在的同一项目。
  • REGION_ID:您希望次要实例所在的区域的 ID。
  • NETWORK:用于创建实例的网络。必须采用以下格式:projects/NETWORK_PROJECT_ID/global/networks/NETWORK_ID。网络 ID 必须与服务连接政策使用的网络 ID 相匹配。否则,您无法创建次要实例。
  • PRIMARY_INSTANCE_PATH:主实例的路径。例如:projects/my-project/locations/us-central1/instances/my-primary-instance。 您可以选择项目中的任何实例作为主实例,只要该实例不是辅助实例即可。

例如:

gcloud memorystore instances create my-secondary-instance \
--project=my-project \
--location=us-central1 \
--cross-instance-replication-config-role=secondary \
--psc-auto-connections=network=projects/my-project/global/networks/default,projectId=my-project \
--primary-instance=projects/my-project/locations/us-central1/instances/my-primary-instance

查看辅助实例

您可以使用Google Cloud 控制台或 Google Cloud CLI 查看有关辅助实例的摘要信息。

控制台

  1. 在 Google Cloud 控制台中,前往 Memorystore for Valkey 页面。

    Memorystore for Valkey

  2. 点击主实例旁边的展开箭头。此实例是您要查看其信息的辅助实例的父实例。

  3. 点击辅助实例。系统会显示有关该实例的摘要信息。

gcloud

如需查看有关次要实例的信息(包括列出复制组中主实例和次要实例的成员资格字段),请使用 gcloud memorystore instances describe 命令。

gcloud memorystore instances describe INSTANCE_ID \
--project=PROJECT_ID \
--location=REGION_ID

进行以下替换:

  • INSTANCE_ID:次要实例的 ID
  • PROJECT_ID:包含辅助实例的项目的 ID
  • REGION_ID:次要实例所在区域的 ID

执行切换

通过切换,您可以将次要实例提升为主实例,从而反转主实例和次要实例的角色,以实现灾难恢复。如需了解详情,请参阅跨区域复制简介

您可以使用 Google Cloud 控制台或 Google Cloud CLI 执行切换。

控制台

  1. 在 Google Cloud 控制台中,前往 Memorystore for Valkey 页面。

    Memorystore for Valkey

  2. 点击主实例旁边的展开箭头。此实例是您要切换到的次要实例的父实例。

  3. 点击辅助实例。

  4. 点击提升为主

  5. 要将次要实例提升为主实例吗?对话框中,输入次要实例的 ID,然后点击提升

切换完成后,您必须将应用重新连接到新的主实例。

gcloud

如需执行切换,请使用 gcloud memorystore instances update 命令。

gcloud memorystore instances update INSTANCE_ID \
--project=PROJECT_ID \
--location=REGION_ID \
--clear-primary-instance \
--cross-instance-replication-config-role=primary \
--cross-instance-replication-config-secondary-instances=[instance=SECONDARY_INSTANCE_PATH]

进行以下替换:

  • INSTANCE_ID:您要通过执行切换操作来升级为主要实例的次要实例的 ID。
  • PROJECT_ID:包含次要实例的项目的 ID。
  • REGION_ID:次要实例所在区域的 ID。
  • SECONDARY_INSTANCE_PATH:次要实例的路径。例如:projects/my-project/locations/us-central1/instances/my-secondary-instance

    如果您有多个辅助实例,请用英文逗号分隔每个实例。例如:[instance=projects/my-project/locations/us-central1/instances/my-first-secondary-instance,instance=projects/my-project/locations/europe-west1/instances/my-second-secondary-instance]

假设您有以下实例,它们包含在 my-project 项目中:

  • instance-1:此主实例位于 us-east1 区域。
  • instance-2:此次要实例位于 asia-east1 区域中。
  • instance-3:此次要实例位于 southamerica-east1 区域中。

您想反转 instance-1instance-2 的角色,使 instance-2 成为新的主实例,而 instance-1 成为辅助实例。

为此,请使用以下代码:

gcloud memorystore instances update instance-2 \
--project=my-project \
--location=asia-east1 \
--clear-primary-instance \
--cross-instance-replication-config-role=primary \
--cross-instance-replication-config-secondary-instances=[instance=projects/my-project/locations/us-east1/instances/instance-1,instance=projects/my-project/locations/southamerica-east1/instances/instance-3]

切换完成后,您必须将应用重新连接到新的主实例。

分离次要实例

如果将一个或多个次要实例从主实例分离,系统会将其设为功能齐全且接受读取和写入的独立实例。 如需了解详情,请参阅如何管理跨区域复制

您可以使用 Google Cloud 控制台或 Google Cloud CLI 分离辅助实例。

分离次要实例

本部分介绍了如何将次要实例从其主实例分离。

控制台

  1. 在 Google Cloud 控制台中,前往 Memorystore for Valkey 页面。

    Memorystore for Valkey

  2. 点击主实例。这是您要从主实例分离的次实例的父实例。

  3. 在侧边栏中,点击辅助实例标签页。

  4. 选中要从主实例分离的次要实例的 ID 旁边的复选框。

  5. 点击从主账号中分离

  6. 分离辅助实例?对话框中,输入辅助实例的 ID,然后点击分离

gcloud

如需分离次要实例,请使用 gcloud memorystore instances update 命令。

gcloud memorystore instances update INSTANCE_ID \
--project=PROJECT_ID \
--location=REGION_ID \
--cross-instance-replication-config-role=none \
--clear-primary-instance

替换以下内容:

  • INSTANCE_ID:要分离的次要实例的 ID
  • PROJECT_ID:包含辅助实例的项目的 ID
  • REGION_ID:次要实例所在的区域

分离多个次要实例

本部分介绍了如何从主实例分离多个辅助实例。您还可以使用本部分中的过程将不可用的辅助实例从其主实例分离。

控制台

  1. 在 Google Cloud 控制台中,前往 Memorystore for Valkey 页面。

    Memorystore for Valkey

  2. 点击主实例。这是您要从主实例分离的次要实例的父级。

  3. 在侧边栏中,点击辅助实例标签页。

  4. 选中要从主实例分离的辅助实例的 ID 旁边的复选框。

  5. 点击从主账号中分离

  6. 要分离次要实例吗?对话框中,执行以下操作:

    1. 输入次要实例的 ID。使用英文逗号分隔 ID。

    2. 点击分离

gcloud

如需分离多个次要实例,请使用 gcloud memorystore instances update 命令。

gcloud memorystore instances update PRIMARY_INSTANCE_ID \
--project=PROJECT_ID \
--location=PRIMARY_INSTANCE_REGION_ID \
--remove-cross-instance-replication-config-secondary-instances=[instance=SECONDARY_INSTANCES] \
--cross-instance-replication-config-role=none

进行以下替换:

  • PRIMARY_INSTANCE_ID:主实例的 ID。
  • PROJECT_ID:包含辅助实例的项目的 ID。
  • PRIMARY_INSTANCE_REGION_ID:主实例所在区域的 ID。
  • SECONDARY_INSTANCES:要分离的次要实例。使用英文逗号分隔实例 ID。每个次要实例都必须采用以下格式:projects/PROJECT_ID/locations/SECONDARY_INSTANCE_REGION_ID/instances/INSTANCE_ID

例如:

gcloud memorystore instances update my-primary-instance \
--project=my-project \
--location=us-central1 \
--remove-cross-instance-replication-config-secondary-instances=[instance=projects/my-project/locations/us-west4/instances/my-secondary-instance-1,instance=projects/my-project/locations/asia-southeast2/instances/my-secondary-instance-2] \
--cross-instance-replication-config-role=none

您还可以通过指定您不想分离的实例列表,将次要实例从主实例分离。 Memorystore for Valkey 会分离您未在此列表中包含的任何实例。

假设您有以下次要实例:

  • instance-1:此实例位于 us-east1 区域。
  • instance-2:此实例位于 asia-east1 区域中。

您要从 my-primary-instance 中分离这两个辅助实例。此主实例位于 us-central1 区域,包含在 my-project 项目中。

如需分离辅助实例,请使用以下代码:

gcloud memorystore instances update my-primary-instance \
--project=my-project \
--location=us-central1 \
--cross-instance-replication-config-secondary-instances=[]
--cross-instance-replication-config-role=none

在此示例中,由于 null [] 值已分配给 --cross-instance-replication-config-secondary-instances 参数,因此 Memorystore for Valkey 会将所有辅助实例与主实例分离。

更新实例设置

本部分提供了用于更新实例设置的链接。更新实例设置的过程因您更改的是主实例还是次要实例的设置而异。如需详细了解如何更新设置,请参阅实例设置

更新主实例上的设置

您必须在主实例上更改以下设置。完成后,Memorystore for Valkey 会将更改同步到辅助实例。

更新次要实例上的设置

您必须在辅助实例上更改以下设置:

删除使用跨区域复制功能的实例

本部分介绍了如何删除使用跨区域复制的主实例和次要实例。

删除主实例

如需删除主实例,请执行以下操作:

  1. 分离删除所有辅助实例。
  2. 如需删除主实例,请按照删除实例中的说明操作。

为防止意外删除,您无法同时删除主实例和辅助实例。

删除次要实例

如需删除辅助实例,请按照删除实例中的说明操作。对于实例 ID,请使用次要实例的 ID。