你当前正在访问 Microsoft Azure Global Edition 技术文档网站。 如果需要访问由世纪互联运营的 Microsoft Azure 中国技术文档网站,请访问 https://docs.azure.cn

使用客户管理的密钥对 Azure Database for PostgreSQL 单一服务器进行数据加密

适用于:Azure Database for PostgreSQL 单一服务器

重要

Azure Database for PostgreSQL - 单一服务器即将停用。 强烈建议升级到 Azure Database for PostgreSQL 灵活服务器。 有关迁移到 Azure Database for PostgreSQL 灵活服务器的详细信息,请参阅 Azure Database for PostgreSQL 单一服务器的最新动态

Azure PostgreSQL 利用 Azure 存储加密通过 Microsoft 管理的密钥来默认加密静态数据。 对于 Azure PostgreSQL 用户,这与其他数据库(例如 SQL Server)中的透明数据加密 (TDE) 非常类似。 许多组织需要使用客户管理的密钥完全控制对数据的访问。 通过使用客户管理的密钥对 Azure Database for PostgreSQL 单一服务器进行数据加密,让你能够创建自己的密钥 (BYOK) 来保护静态数据。 通过它,组织还可在管理密钥和数据时实现职责分离。 通过客户托管的加密,密钥的生命周期、密钥使用权限以及对密钥操作的审核都由你负责和完全控制。

在服务器级别使用客户管理的密钥对 Azure Database for PostgreSQL 单一服务器进行数据加密。 客户管理的密钥被称为密钥加密密钥 (KEK),它在给定的服务器中用于对该服务使用的数据加密密钥 (DEK) 进行加密。 KEK 是一种非对称密钥,它存储在客户自有和客户管理的 Azure Key Vault 实例中。 本文稍后将更详细地描述密钥加密密钥 (KEK) 和数据加密密钥 (DEK)。

Key Vault 是一种基于云的外部密钥管理系统。 它具有高可用性,并为 RSA 加密密钥提供可缩放的安全存储,根据需要由经过 FIPS 140 验证的硬件安全模块 (HSM) 提供支持。 它不允许直接访问存储的密钥,而是为已获授权的实体提供加密和解密服务。 Key Vault 可生成密钥并将其导入,或者从本地 HSM 设备传输密钥

注意

此功能适用于所有 Azure 区域,其中 Azure Database for PostgreSQL 单一服务器支持“常规用途”和“内存优化”定价层。 有关其他限制,请参阅限制部分。

优点

使用客户管理的密钥对 Azure Database for PostgreSQL 单一服务器进行数据加密提供以下优势:

  • 通过删除密钥并使数据库不可访问,数据访问完全由你控制。
  • 完全控制密钥生命周期,包括根据公司策略轮换密钥。
  • 在 Azure Key Vault 中集中管理和整理密钥。
  • 无论是否使用客户管理的密钥 (CMK),启用加密都不会对性能产生额外影响,因为 PostgreSQL 在这两种方案中均依赖 Azure 存储层进行数据加密,唯一区别在于当使用 CMK 时,执行实际数据加密的 Azure 存储加密密钥是使用 CMK 进行加密的。
  • 可实现安全专员与 DBA 和系统管理员之间的职责分离。

术语和说明

数据加密密钥 (DEK) :对称 AES256 密钥,用于加密数据分区或数据块。 使用不同的密钥加密每个数据块可以增加加密分析攻击的难度。 资源提供程序或应用程序实例需要 DEK 访问权限才能加密和解密特定的块。 将 DEK 替换为新密钥时,只需使用新密钥对其关联的块中的数据重新加密。

密钥加密密钥 (KEK) :用于加密 DEK 的加密密钥。 KEK 始终在 Key Vault 中,这使得 DEK 本身能得到加密和控制。 具有 KEK 访问权限的实体可能不是需要 DEK 的实体。 由于解密 DEK 需要 KEK,因此 KEK 实际上构成了一个单点机制:删除 KEK 即可删除 DEK。

DEK 使用 KEK 加密且单独存储。 只有有权访问 KEK 的实体才能解密这些 DEK。 有关详细信息,请参阅静态加密中的安全性

使用客户管理的密钥进行数据加密的工作原理

显示“创建自己的密钥”概述的关系图

若要使 PostgreSQL 服务器使用存储在 Key Vault 中的客户管理的密钥对 DEK 进行加密,Key Vault 管理员需向服务器授予以下访问权限:

  • get:用于检索 Key Vault 中密钥的公共部分和属性。
  • wrapKey:可加密 DEK。 加密的 DEK 存储在 Azure Database for PostgreSQL 中。
  • unwrapKey:可解密 DEK。 Azure Database for PostgreSQL 需要解密的 DEK 对数据进行加密/解密

Key Vault 管理员还可启用 Key Vault 审核事件的日志记录,便于稍后对其进行审核。

当服务器配置为使用存储在 Key Vault 中的客户管理的密钥时,该服务器会将 DEK 发送到 Key Vault 进行加密。 Key Vault 返回存储在用户数据库中已加密的 DEK。 同样在必要时,服务器会将受保护的 DEK 发送到 Key Vault 进行解密。 如果启用了日志记录,审计可使用 Azure Monitor 查看 Key Vault 审核事件日志。

为 Azure Database for PostgreSQL 单一服务器配置数据加密的要求

下面是 Key Vault 的配置要求:

  • Key Vault 和 Azure Database for PostgreSQL 单一服务器必须属于同一个 Microsoft Entra 租户。 不支持跨租户的 Key Vault 和服务器交互。 之后若要移动 Key Vault 资源,需要重新配置数据加密。
  • 必须将“已删除保管库的保留天数”设为 90 天来设置密钥保管库。 如果已将现有的密钥保管库配置为较小的数字,则需要创建新的密钥保管库,因为在创建后不能对其进行修改。
  • 启用 Key Vault 上的软删除功能,防止在意外删除密钥(或 Key Vault)时丢失数据。 被软删除的资源将保留 90 天,除非用户在此期间恢复或清除它们。 “恢复”和“清除”操作均自带与 Key Vault 访问策略关联的权限。 软删除功能默认关闭,但你可通过 PowerShell 或 Azure CLI 启用它(请注意,无法通过 Azure 门户启用)。
  • 启用清除保护对已删除的保管库和保管库对象执行强制保留期
  • 通过唯一托管标识,使用 get、wrapKey 和 unwrapKey 权限授权 Azure Database for PostgreSQL 单一服务器访问 Key Vault。 在 Azure 门户中,当 PostgreSQL 单一服务器上启用数据加密时,将自动创建唯一“服务”标识。 有关使用 Azure 门户时的详细分步说明,请参阅通过 Azure 门户对 Azure Database for PostgreSQL 单一服务器进行数据加密

下面是客户管理的密钥的配置要求:

  • 用于加密 DEK 的客户管理的密钥只能是非对称的 RSA 2048。
  • 密钥激活日期(如果已设置)必须是过去的日期和时间。 到期日期(若已设置)必须是将来的日期和时间。
  • 密钥必须处于“已启用”状态。
  • 若要导入现有密钥到密钥保管库,请确保以受支持的文件格式(.pfx.byok.backup)提供该密钥。

建议

通过客户管理的密钥使用数据加密时,请查看下列 Key Vault 配置建议:

  • 在 Key Vault 中设置资源锁可控制谁能删除该关键资源,并防止意外或未经授权的删除。

  • 对所有加密密钥启用审核和报告功能。 Key Vault 提供可轻松注入到其他安全信息和事件管理工具的日志。 Azure Monitor Log Analytics 就是一项已集成的服务。

  • 确保 Key Vault 和 Azure Database for PostgreSQL 单一服务器位于同一区域,从而保证能更快地访问 DEK 的“包装”和“取消包装”操作。

  • 锁定 Azure KeyVault,使其只能用于专用终结点和所选网络,且仅允许使用受信任的 Microsoft 服务来保护资源。

    trusted-service-with-AKV

下面是客户管理的密钥的配置建议:

  • 将客户管理的密钥副本保存在安全的位置,或将其托管到托管服务。

  • 如果 Key Vault 生成密钥,请在首次使用该密钥之前创建密钥备份。 只能将备份还原到 Key Vault。 要详细了解备份命令,请参阅 Backup-AzKeyVaultKey

无法访问客户管理的密钥的情形

在 Key Vault 中使用客户管理的密钥配置数据加密时,服务器必须保持联机状态才能持续访问该密钥。 如果服务器无法再访问 Key Vault 中客户管理的密钥,它将在 10 分钟内开始拒绝所有连接。 服务器会发出相应的错误消息,并将服务器状态更改为“无法访问”。 使服务器达到此状态的部分原因如下:

  • 如果为 Azure Database for PostgreSQL 单一服务器创建“时间点还原”服务器,而前者启用了数据加密,则新创建的服务器将处于“无法访问”状态。 可通过 Azure 门户CLI 修复服务器状态。
  • 如果为 Azure Database for PostgreSQL 单一服务器创建只读副本,而该服务器启用了数据加密,则副本服务器将处于“无法访问”状态。 可通过 Azure 门户CLI 修复服务器状态。
  • 如果删除 KeyVault,Azure Database for PostgreSQL 单一服务器将无法访问密钥,并将转为“无法访问”状态。 请恢复 Key Vault 并重新验证数据加密,使服务器的状态变为“可用”。
  • 如果从 KeyVault 中删除密钥,Azure Database for PostgreSQL 单一服务器将无法访问密钥,并将转为“无法访问”状态。 请恢复密钥并重新验证数据加密,使服务器的状态变为“可用”。
  • 如果 Azure KeyVault 中存储的密钥过期,则该密钥将失效,且 Azure Database for PostgreSQL 单一服务器将变为“无法访问”状态。 请使用 CLI 将密钥到期日期延后,然后重新验证数据加密,使服务器的状态变为“可用”。

从 Key Vault 意外撤消密钥访问

可能会发生这样的情况:对 Key Vault 具有足够访问权限的人员通过下列方式意外禁用了服务器对密钥的访问:

  • 从服务器中撤消 Key Vault 的 get、wrapKey 和 unwrapKey 权限。

  • 删除密钥。

  • 删除 Key Vault。

  • 更改 Key Vault 的防火墙规则。

  • 在 Microsoft Entra ID 中删除服务器的托管标识。

在 Key Vault 中监视客户管理的密钥

若要监视数据库状态并在透明数据加密保护程序访问权限丢失时发出警报,请配置以下 Azure 功能:

  • Azure 资源运行状况:在与数据库的第一次连接遭到拒绝后,已失去客户密钥访问权限的无法访问的数据库将显示为“无法访问”。

  • 活动日志:对 Key Vault 中客户管理的密钥访问失败时,活动日志中会添加相应条目。 如果为这些事件创建警报,就可尽快恢复访问。

  • 操作组:定义这些组,使其根据首选项向你发送通知和警报。

在 Key Vault 中使用客户管理的密钥进行还原和复制

在使用 Key Vault 中存储的客户管理的密钥对 Azure Database for PostgreSQL 单一服务器进行加密后,还将所有新创建的服务器副本进行加密。 可通过本地或异地还原操作,或通过只读副本创建这个新副本。 可更改该副本,使其反映出用于加密的客户管理的新密钥。 当客户管理的密钥更改时,服务器的旧备份将开始使用最新的密钥。

为避免在还原或只读副本创建期间设置客户管理的数据加密时出现问题,有必要在主服务器和还原/副本服务器上执行以下步骤:

  • 通过主要 Azure Database for PostgreSQL 单一服务器启动还原或只读副本创建过程。
  • 使新创建的(还原/副本)服务器保持在无法访问的状态,因为其唯一标识尚无权访问 Key Vault。
  • 在还原/副本服务器上,重新验证数据加密设置中客户管理的密钥。 这可确保为新创建的服务器授予对 Key Vault 中存储的密钥进行包装和取消包装的权限。

限制

对于 Azure Database for PostgreSQL,对使用客户管理的密钥 (CMK) 加密静态数据的支持有少数限制 -

  • 对此功能的支持仅限“常规用途”和“内存优化”定价层。

  • 此功能仅在支持高达 16 TB 的存储的区域和服务器上受支持。 有关支持存储最多 16 TB 的 Azure 区域的列表,请参阅此处文档中的“存储”部分

    注意

    • 在上面列出的区域中创建的所有新 PostgreSQL 服务器都提供对使用客户管理器密钥进行加密的支持。 时间点还原 (PITR) 服务器或只读副本不符合条件,尽管其在理论上是“新的”。
    • 若要验证预配的服务器是否最多支持 16 TB,可以转到门户中的“定价层”边栏选项卡,并查看预配服务器支持的最大存储大小。 如果可以将滑块向上移动到 4 TB,则服务器可能不支持使用客户管理的密钥进行加密。 但是,始终使用服务托管密钥对数据进行加密。 如果有任何疑问,请联系 AskAzureDBforPostgreSQL@service.microsoft.com。
  • 仅支持使用 RSA 2048 加密密钥进行加密。

后续步骤

了解如何通过 Azure 门户设置使用 Azure Database for PostgreSQL 单一服务器的客户管理的密钥进行数据加密的操作