本页面介绍了如何通过创建和管理次要实例来使用跨区域复制。
如需从概念上大致了解跨区域复制,请参阅跨区域复制简介。
创建次要实例
创建辅助实例时,Memorystore for Valkey 会复制主实例的一些设置并将其应用于辅助实例。如需了解详情,请参阅实例设置。
您可以使用Google Cloud 控制台或 Google Cloud CLI 在 Memorystore for Valkey 中创建辅助实例。
控制台
在 Google Cloud 控制台中,前往 Memorystore for Valkey 页面。
点击主实例。主实例是您要创建的辅助实例的父实例。
在侧边栏中,点击辅助实例标签页。
点击添加辅助实例。
在添加辅助实例窗口中,进行以下更改:
在实例 ID 字段中,输入您要创建的次要实例的 ID。ID 的长度必须介于 1 到 63 个字符之间,且只能使用小写字母、数字或连字符。必须以小写字母开头,以小写字母或数字结尾,并且在其区域中是唯一的。
从区域菜单中,选择您希望辅助实例所在的区域。
在可用区级可用性部分,选择以下选项之一:
如果您希望实例的所有分片和副本都分布在 Memorystore for Valkey 创建实例的区域中的三个可用区内,请选择多可用区选项。
例如,如果您选择的区域为
us-central1
,并选择多可用区选项,则 Memorystore for Valkey 会将实例的分片和副本分布在us-central1-a
、us-central1-b
和
us-central1-c
可用区中。如果发生可用区故障,实例中的节点将故障切换到副本。如果您希望实例的所有分片和副本都位于 Memorystore for Valkey 创建实例的区域中的一个可用区内,请选择单可用区选项,然后从可用区菜单中选择可用区。
通过使用单个可用区,您可以降低网络费用。不过,如果发生可用区级故障,则不会进行故障切换。
从副本菜单中,为实例选择副本数量(每个分片)。您可以有 0 个、1 个或 2 个副本。
从网络菜单中,为实例选择一个网络。如需详细了解 Memorystore for Valkey 的网络,请参阅网络。
点击添加辅助实例。
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 查看有关辅助实例的摘要信息。
控制台
在 Google Cloud 控制台中,前往 Memorystore for Valkey 页面。
点击主实例旁边的展开箭头。此实例是您要查看其信息的辅助实例的父实例。
点击辅助实例。系统会显示有关该实例的摘要信息。
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 执行切换。
控制台
在 Google Cloud 控制台中,前往 Memorystore for Valkey 页面。
点击主实例旁边的展开箭头。此实例是您要切换到的次要实例的父实例。
点击辅助实例。
点击提升为主。
在要将次要实例提升为主实例吗?对话框中,输入次要实例的 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-1
和 instance-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 分离辅助实例。
分离次要实例
本部分介绍了如何将次要实例从其主实例分离。
控制台
在 Google Cloud 控制台中,前往 Memorystore for Valkey 页面。
点击主实例。这是您要从主实例分离的次实例的父实例。
在侧边栏中,点击辅助实例标签页。
选中要从主实例分离的次要实例的 ID 旁边的复选框。
点击从主账号中分离。
在分离辅助实例?对话框中,输入辅助实例的 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:次要实例所在的区域
分离多个次要实例
本部分介绍了如何从主实例分离多个辅助实例。您还可以使用本部分中的过程将不可用的辅助实例从其主实例分离。
控制台
在 Google Cloud 控制台中,前往 Memorystore for Valkey 页面。
点击主实例。这是您要从主实例分离的次要实例的父级。
在侧边栏中,点击辅助实例标签页。
选中要从主实例分离的辅助实例的 ID 旁边的复选框。
点击从主账号中分离。
在要分离次要实例吗?对话框中,执行以下操作:
输入次要实例的 ID。使用英文逗号分隔 ID。
点击分离。
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 会将更改同步到辅助实例。
更新次要实例上的设置
您必须在辅助实例上更改以下设置:
删除使用跨区域复制功能的实例
本部分介绍了如何删除使用跨区域复制的主实例和次要实例。
删除主实例
如需删除主实例,请执行以下操作:
为防止意外删除,您无法同时删除主实例和辅助实例。
删除次要实例
如需删除辅助实例,请按照删除实例中的说明操作。对于实例 ID,请使用次要实例的 ID。