Azure Database for PostgreSQL 灵活服务器中只读副本的虚拟终结点

适用于: Azure Database for PostgreSQL 灵活服务器

虚拟终结点是读写和只读侦听器终结点,无论 Azure Database for PostgreSQL 灵活服务器实例的当前角色如何,它们都保持一致。 这意味着,不必在执行“提升到主服务器”操作后更新应用程序的连接字符串,因为终结点会在角色更改后自动指向正确的实例。

涉及虚拟终结点的所有操作,无论是添加、编辑还是删除,都在主服务器的上下文中执行。 在 Azure 门户中,在主服务器页下管理这些终结点。 同样,在使用 CLI、REST API 等工具或其他实用工具时,命令和操作会针对用于终结点管理的主服务器执行。

虚拟终结点提供两种不同类型的连接点:

写入方终结点(读/写):此终结点始终指向当前主服务器。 它确保写入操作定向到正确的服务器,而不管用户触发的任何提升操作。 无法更改此终结点以指向副本

只读终结点:用户可以配置此终结点以指向只读副本或主服务器。 但是,它一次只能以一个服务器为目标。 不支持多个服务器之间的负载均衡。 可以随时调整此终结点的目标服务器(无论是在提升之前还是之后)。

备注

每个主服务器及其一个副本只能创建一个编写器和一个只读终结点。

虚拟终结点和提升行为

如果发生晋升操作,这些端点的行为仍然是可预测的。 以下各节深入介绍了这些终结点如何对“提升到主服务器”和“提升到独立服务器”场景做出反应。

虚拟终结点 原始目标 触发“提升到主服务器”时的行为 触发“提升到独立服务器”时的行为
编写器终结点 主服务器 指向新的主服务器。 保持不变。
只读终结点 副本 指向新副本(之前的主服务器)。 指向主服务器。
只读终结点 主服务器 不支持。 保持不变。

触发“提升到主服务器”时的行为

  • 写入方终结点:此终结点将更新为指向新的主服务器,以反映角色切换。
  • 只读端点
    • 如果只读终结点指向副本:提升操作后,只读终结点将指向新副本(之前的主服务器)
    • 如果只读终结点指向主服务器:为使提升操作能够正常运行,只读终结点必须定向到要提升的服务器。 在这种情况下,指向主服务器不受支持,必须在进行提升之前重新配置为指向副本。

触发“提升到独立服务器并从复制中删除”时的行为

  • 写入方终结点:此终结点保持不变。 它继续将流量定向到服务器,并拥有主要角色。
  • 只读终结点
    • 如果只读终结点指向副本:只读终结点从提升的副本重定向为指向主服务器
    • 如果只读终结点指向主服务器:只读终结点保持不变,继续指向同一服务器。

在时点恢复 (PITR) 或快照还原期间使用虚拟终结点实现一致的主机名

本部分介绍如何在 Azure Database for PostgreSQL 灵活服务器中使用虚拟终结点,以在时间点恢复(PITR)或快照还原期间保持主机名的一致性,确保应用程序的连接字符串保持不变。 执行以下步骤:

  1. 将虚拟终结点添加到主服务器:

    • 在 Azure 门户中导航到主服务器实例。
    • 导航到“复制”选项卡,然后在“虚拟终结点”下,单击“添加虚拟终结点”
    • 使用一致的主机名(如 mydb-virtual-endpoint.postgres.database.azure.com)配置虚拟终结点。
    • 保存配置。
    • 更新应用程序以在连接字符串中使用此虚拟终结点。
  2. 执行时点恢复 (PITR) 或快照还原:

    • 启动恢复:
      • 转到主服务器的“备份”部分。
      • 选择适当的还原选项(PITRsnapshot)并指定所需的时间点。
    • 更新虚拟端点:
      • 创建新实例后,导航回旧的主服务器“复制”选项卡。
      • 从原始主服务器中移除虚拟终结点。 旧主服务器应处于 succeeded 状态,以删除虚拟终结点
      • 将相同的虚拟终结点添加到新创建的服务器。
  3. 验证

    • 确保应用程序使用虚拟终结点进行连接,并在恢复后验证数据库操作。