配置高可用性

高可用性配置的目的是当数据库集群实例不可用时减少停机时间。当实例内存不足时,可能会发生这种情况。借助高可用性,您的数据可以继续供客户端应用使用。

在站点内,该配置由主实例和备用副本组成。在事务被报告为已提交之前,对主实例执行的所有写入操作都会复制到备用副本。如果实例发生故障,您可以请求将备用副本作为新的主实例。 然后,应用流量会被重新路由到新的主实例。此过程称为故障切换

您可以随时手动触发故障切换。故障切换涉及以下流程(按顺序列出):

  1. GDC 使主实例离线。

  2. GDC 将备用副本转变为新的活跃数据库集群。

  3. GDC 会删除之前的活跃数据库集群。

  4. GDC 会创建一个新的备用副本。

对于 AlloyDB Omni 和 PostgreSQL 数据库集群,您可以启用或停用同可用区高可用性。

更新现有集群

您可以更新现有数据库集群的高可用性设置:

控制台

  1. 在导航菜单中,选择数据库服务

  2. 在数据库集群列表中,点击要更新的数据库集群。

  3. 高可用性部分中,依次选择修改 修改

    修改数据库集群的高可用性设置。

  4. 选择启用同可用区备用,以开启或关闭与主数据库集群位于同一可用区的备用实例的可用性。

  5. 点击保存

  6. 查看数据库集群列表的高可用性列中的状态,验证数据库集群是否反映了您的高可用性更新。

gdcloud

  1. 更新数据库集群的高可用性配置:

    gdcloud database clusters update CLUSTER_NAME \
        --availability-type HA_TYPE
    

    替换以下内容:

    • CLUSTER_NAME:数据库集群的名称。
    • HA_TYPE:数据库集群的高可用性级别。您可以设置 zonalzonal_ha。默认情况下,系统会设置 zonal 值。
  2. 验证数据库集群是否反映了高可用性更新:

    gdcloud database clusters list
    

API

  1. 更新数据库集群的高可用性配置:

      kubectl patch dbcluster.DBENGINE_NAME.dbadmin.gdc.goog DBCLUSTER_NAME \
        -n USER_PROJECT \
        -p '{"spec": {"availability": {"enableHighAvailability": HA_ENABLED}}}' \
        --type=merge
    

    执行以下变量替换操作:

    • DBENGINE_NAME:数据库引擎的名称。可以是 alloydbomnipostgresqloracle
    • DBCLUSTER_NAME:数据库集群的名称。
    • USER_PROJECT:创建数据库集群的用户项目的名称。
    • HA_ENABLED:数据库集群的高可用性级别。您可以设置 truefalse。默认情况下,系统会设置 false 值。
  2. 验证数据库集群是否反映了高可用性更新:

    kubectl get dbcluster.DBENGINE_NAME.dbadmin.gdc.goog DBCLUSTER_NAME \
      -n USER_PROJECT \
      -o yaml
    

触发故障切换

如果您已为数据库集群配置高可用性,则可以触发故障切换。如需触发故障切换,请完成以下步骤:

控制台

  1. 在导航菜单中,选择数据库服务

  2. 在数据库集群列表中,点击要触发故障切换的数据库集群。数据库集群必须启用高可用性才能符合故障切换条件。

  3. 点击故障切换

  4. 输入集群的 ID 作为确认短语,然后点击故障切换以触发故障切换流程。

gdcloud

  • 触发数据库集群的故障切换:

    gdcloud database clusters failover CLUSTER_NAME
    

    CLUSTER_NAME 替换为数据库集群的名称。

API

  apiVersion: fleet.dbadmin.gdc.goog/v1
  kind: Failover
  metadata:
    name: FAILOVER_NAME
  spec:
    dbclusterRef: DBCLUSTER_NAME

执行以下变量替换操作:

  • DBCLUSTER_NAME,数据库集群的名称。
  • FAILOVER_NAME,故障切换的唯一名称,例如 failover-sample