Настройка ключей, управляемых клиентом, для учетной записи Azure Cosmos DB с помощью Azure Key Vault
Область применения: Nosql Mongodb Кассандра Гремлин Таблица
Данные, хранящиеся в учетной записи Azure Cosmos DB, автоматически шифруются с помощью управляемых службой ключей, управляемых корпорацией Майкрософт. Однако можно добавить второй уровень шифрования с помощью ключей, которыми вы управляете. Эти ключи называются ключами, управляемыми клиентом (или CMK). Управляемые клиентом ключи хранятся в экземпляре Azure Key Vault.
В этой статье описывается, как настроить шифрование с помощью ключей, управляемых клиентом, во время создания учетной записи Azure Cosmos DB. В этом примере межтенантный сценарий учетная запись Azure Cosmos DB находится в клиенте, управляемом независимым поставщиком программного обеспечения (ISV), который называется поставщиком услуг. Ключ, используемый для шифрования учетной записи Azure Cosmos DB, находится в хранилище ключей в другом клиенте, управляемом клиентом.
Сведения о кросс-тенантных ключах, управляемых клиентом
Многие поставщики служб, создающие предложения SaaS (программное обеспечение как услуга) в Azure, хотят предоставить своим клиентам возможность управлять собственными ключами шифрования. Ключи, управляемые клиентом, позволяют поставщику службы шифровать данные клиента с помощью ключа шифрования, управляемого клиентом поставщика службы и недоступного поставщику службы. В Azure клиент поставщика услуг может использовать Azure Key Vault для управления ключами шифрования в собственном клиенте и подписке Microsoft Entra.
Службы и ресурсы платформы Azure, принадлежащие поставщику службы и находящиеся в арендаторе поставщика службы, требуют доступа к ключу из арендатора клиента для выполнения операций шифрования и расшифровки.
На рисунке ниже показано шифрование неактивных данных с использованием федеративного удостоверения в рабочем процессе кросс-тенантного CMK, охватывающем поставщика службы и клиента.
В приведенном выше примере существует два клиента Microsoft Entra: клиент независимого поставщика услуг (клиент 1) и клиент клиента (клиент 2). Клиент 1 содержит службы платформы Azure и клиент 2 размещает хранилище ключей клиента.
Регистрация мультитенантного приложения создается поставщиком услуг в клиенте 1. Учетные данные федеративного удостоверения создаются в этом приложении с помощью управляемого удостоверения, назначаемого пользователем. Затем имя и идентификатор приложения отправляются клиенту.
Пользователь с соответствующими разрешениями устанавливает приложение поставщика услуг в клиенте клиента, клиент 2. Затем пользователь предоставляет субъекту-службе, связанному с установленным приложением, доступ к хранилищу ключей клиента. Кроме того, клиент сохраняет ключ шифрования или ключ, управляемый клиентом, в хранилище ключей. Клиент отправляет сведения о расположении ключа (URL-адрес ключа) поставщику службы.
Теперь у поставщика службы есть следующее:
- Идентификатор приложения для мультитенантного приложения, установленного в клиенте клиента, который был предоставлен доступ к управляемому клиентом ключу.
- Управляемое удостоверение, настроенное в качестве учетных данных в мультитенантном приложении.
- сведения о расположении ключа в хранилище ключей клиента.
С этими тремя параметрами поставщик услуг подготавливает ресурсы Azure в клиенте 1 , которые можно зашифровать с помощью ключа, управляемого клиентом, в клиенте 2.
Давайте разделим указанное выше комплексное решение на три этапа:
- Поставщик службы настраивает удостоверения.
- Клиент предоставляет мультитенантным приложениям поставщика услуг доступ к ключу шифрования в Azure Key Vault.
- Поставщик службы шифрует данные в ресурсе Azure с помощью CMK.
Для большинства приложений поставщиков служб операции настройки на этапе 1 выполняются однократно. Операции на этапах 2 и 3 будут повторяться для каждого клиента.
Этап 1. Поставщик услуг настраивает приложение Microsoft Entra
Этап | Description | Минимальная роль в Azure RBAC | Минимальная роль в Microsoft Entra RBAC |
---|---|---|---|
1. | Создайте новую мультитенантную регистрацию приложения Microsoft Entra или начните с существующей регистрации приложения. Запишите идентификатор приложения (идентификатор клиента) регистрации приложения на портале Azure, в Microsoft API Graph, Azure PowerShell или Azure CLI. | нет | Разработчик приложений |
2. | Создайте управляемое удостоверение, назначаемое пользователем (для использования в качестве учетных данных федеративного удостоверения). Портал Azure / Azure CLI / Azure PowerShell/ Шаблоны Azure Resource Manager |
Участник управляемого удостоверения | нет |
3. | Настройте управляемое удостоверение, назначаемое пользователем, в качестве учетных данных федеративного удостоверения в приложении, чтобы можно было реализовать олицетворение приложения. Справочные материалы по API Graph/ Портал Azure/ Azure CLI/ Azure PowerShell |
нет | Владелец приложения |
4. | Предоставьте клиенту общий доступ к имени приложения и идентификатору приложения, чтобы он смог установить и авторизовать приложение. | нет | нет |
Рекомендации для поставщиков служб
- Шаблоны Azure Resource Manager (ARM) не рекомендуется создавать приложения Microsoft Entra.
- Одно и то же мультитенантное приложение можно использовать для доступа к ключам в любом количестве клиентов, таких как Tenant 2, Tenant 3, Tenant 4 и т. д. В каждом арендаторе создается независимый экземпляр приложения. У этих экземпляров одинаковые идентификаторы приложения, но разные идентификаторы объекта. Таким образом, каждый экземпляр этого приложения авторизуется независимо. Обратите внимание на то, как объект приложения, применяемый для этой функции, используется для секционирования приложения по всем клиентам.
- Приложение может иметь не более 20 учетных данных федеративного удостоверения, что требует от поставщика услуг совместного использования федеративных удостоверений среди своих клиентов. Дополнительные сведения о проектировании федеративных удостоверений и ограничениях см. в разделе "Настройка приложения для доверия к внешнему поставщику удостоверений"
- В редких сценариях поставщик услуг может использовать один объект Application на каждого клиента, но для управления приложениями во всех клиентах требуются значительные затраты на обслуживание.
- В клиенте поставщика услуг невозможно автоматизировать проверку издателя.
Этап 2. Клиент разрешает доступ к хранилищу ключей
Этап | Description | Роли Azure RBAC с минимальными привилегиями | Наименее привилегированные роли Microsoft Entra |
---|---|---|---|
1. | нет | Пользователи с разрешениями на установку приложений | |
2. | Создайте ресурс Azure Key Vault и ключ, используемый в качестве ключа, управляемого клиентом. | Чтобы создать хранилище ключей, требуется роль Участник Key Vault. Чтобы добавить ключ в хранилище ключей, требуется роль специалиста по шифрованию хранилища ключей. |
нет |
3. | Предоставьте удостоверению приложения, для которого получено согласие, доступ к хранилищу ключей Azure, назначив роль пользователя службы шифрования хранилища ключей. | Чтобы назначить приложению роль пользователя службы шифрования хранилища ключей, требуется роль администратора доступа пользователей. | нет |
4. | Скопируйте URL-адрес хранилища ключей и имя ключа в конфигурацию ключей, управляемый клиентом, предложения SaaS. | нет | нет |
Примечание.
Чтобы авторизовать доступ к управляемому HSM для шифрования с помощью CMK, см. пример учетной записи хранения. Дополнительные сведения об управлении ключами с помощью управляемого HSM см. в статье "Управление управляемым HSM с помощью Azure CLI"
Рекомендации для клиентов поставщиков служб
- В клиенте клиента Клиент 2 администратор может задать политики, чтобы запретить пользователям, не являющихся администраторами, устанавливать приложения. Эти политики могут предотвратить создание субъектов-служб пользователями без прав администратора. Если такая политика настроена, пользователи с разрешениями на создание субъектов-служб должны быть вовлечены.
- Доступ к Azure Key Vault можно авторизовать с помощью Azure RBAC или политик доступа. При предоставлении доступа к хранилищу ключей обязательно используйте активный механизм для хранилища ключей.
- Регистрация приложения Microsoft Entra имеет идентификатор приложения (идентификатор клиента). При установке приложения в арендаторе создается субъект-служба. Субъект-служба использует тот же идентификатор приложения, что и регистрация приложения, но создает собственный идентификатор объекта. При авторизации приложения доступа к ресурсам может потребоваться использовать субъект-службу
Name
илиObjectID
свойство.
Этап 3. Поставщик службы шифрует данные в ресурсе Azure с помощью ключа, управляемого клиентом
После завершения этапа 1 и 2 поставщик услуг может настроить шифрование в ресурсе Azure с помощью ключа и хранилища ключей в клиенте клиента и ресурса Azure в клиенте поставщика услуг. Поставщик службы может настроить кросс-тенантные ключи, управляемые клиентом, с помощью клиентских средств, поддерживаемых этим ресурсом Azure, с помощью шаблона ARM или REST API.
Настройка кросс-тенантных ключей, управляемых клиентом
В этом разделе объясняется, как настроить кросс-тенантный ключ, управляемый клиентом (CMK), и зашифровать данные клиента. Вы узнаете, как шифровать данные клиента в ресурсе в Tenant1 с помощью CMK, хранящегося в хранилище ключей в Tenant2. Для этого можно использовать портал Azure, Azure PowerShell или Azure CLI.
Войдите на портал Azure и сделайте следующее.
Поставщик службы настраивает удостоверения
В арендаторе Tenant1 поставщик службы выполняет следующие действия.
Поставщик услуг создает новую регистрацию мультитенантного приложения
Можно создать регистрацию приложения Microsoft Entra с несколькими клиентами или начать с существующей регистрации мультитенантного приложения. Если вы начинаете с существующей регистрации приложения, запишите идентификатор приложения (идентификатор клиента).
Создание регистрации:
Найдите идентификатор Microsoft Entra в поле поиска. Найдите и выберите расширение Идентификатора Microsoft Entra.
В области слева выберите элементы Управление > Регистрация приложений.
Выберите + Создать регистрацию.
Укажите имя регистрации приложения и выберите учетную запись в любом каталоге организации (любой каталог Microsoft Entra — Multitenant).
Выберите Зарегистрировать.
Запишите значение ApplicationId или ClientId приложения.
Поставщик службы создает управляемое удостоверение, назначаемое пользователем
Создайте управляемое удостоверение, назначаемое пользователем, для использования в качестве учетных данных федеративного удостоверения.
В поле поиска введите запрос управляемые удостоверения. Найдите и выберите расширение Управляемые удостоверения.
Выберите + Создать.
Укажите группу ресурсов, регион и имя для управляемого удостоверения.
Выберите Review + create (Просмотреть и создать).
При успешном развертывании запишите значение ResourceId Azure управляемого удостоверения, назначаемого пользователем, которое доступно в разделе Свойства. Например:
/subscriptions/tttttttt-0000-tttt-0000-tttt0000tttt/resourcegroups/XTCMKDemo/providers/Microsoft.ManagedIdentity/userAssignedIdentities/ConsotoCMKDemoUA
Поставщик службы настраивает управляемое удостоверение, назначаемое пользователем, в качестве федеративных учетных данных в приложении
Настройте управляемое удостоверение, назначаемое пользователем, в качестве учетных данных федеративного удостоверения в приложении, чтобы можно было реализовать олицетворение приложения.
Перейдите к идентификатору Microsoft Entra id > Регистрация приложений > приложения.
Выберите Сертификаты и секреты.
Выберите элемент Федеративные учетные данные.
Выберите элемент + Добавить учетные данные.
В разделе Сценарий федеративных учетных данных выберите элемент Ключи, управляемые клиентом.
Щелкните элемент Выберите управляемое удостоверение. В области выберите подписку. В разделе Управляемое удостоверение выберите элемент Управляемое удостоверение, назначаемое пользователем. В поле Выбор найдите созданное ранее управляемое удостоверение и нажмите кнопку Выбрать в нижней части области.
В разделе Сведения об учетных данных укажите имя и необязательное описание учетных данных и нажмите кнопку Добавить.
Поставщик службы отправляет клиенту общий идентификатор приложения
Найдите идентификатор приложения (идентификатор клиента) мультитенантного приложения и поделитесь им с клиентом.
Клиент предоставляет приложению поставщика службы доступ к ключу в хранилище ключей
В арендаторе клиента Tenant2 клиент выполняет следующие действия. Клиент может использовать портал Azure, Azure PowerShell или Azure CLI.
Пользователь, выполняющий действия, должен быть администратором с привилегированной ролью, такой как администратор приложений, администратор облачных приложений или глобальный администратор.
Войдите на портал Azure и сделайте следующее.
Клиент устанавливает приложение поставщика службы в арендаторе клиента
Чтобы установить зарегистрированное приложение поставщика службы в арендаторе клиента, создайте субъект-службу с идентификатором приложения из зарегистрированного приложения. Субъект-службу можно создать с помощью любого из следующих способов:
- Создать субъект-службу можно вручную с помощью Microsoft Graph, Microsoft Graph PowerShell, Azure PowerShell или Azure CLI.
- Создайте URL-адрес предоставления согласия администратора и предоставьте согласие на уровне арендатора для создания субъекта-службы. Вам потребуется предоставить AppId.
Клиент создает хранилище ключей
Чтобы создать хранилище ключей, учетной записи пользователя необходимо назначить роль участника хранилища ключей или другую роль, которая разрешает создание хранилища ключей.
На домашней странице или в меню портала Azure выберите + Создать ресурс. В поле поиска введите запрос хранилища ключей. В списке результатов выберите элемент Хранилища ключей. На странице Хранилища ключей нажмите кнопку Создать.
На вкладке Основные сведения выберите подписку. В разделе Группа ресурсов выберите команду Создать и введите имя группы ресурсов.
Введите уникальное имя хранилища ключей.
Выберите регион и ценовую категорию.
Включите защиту от очистки для нового хранилища ключей.
На вкладке Политика доступа выберите значение Управление доступом на основе ролей Azure для параметра Модель разрешений.
Выберите Просмотр и создание, а затем щелкните Создать.
Запишите имя хранилища ключей и приложения URI, которые обращаются к хранилищу ключей, должны использовать этот URI.
Дополнительные сведения см. в статье Краткое руководство. Создание хранилища ключей с помощью портала Azure.
Назначение клиентом роли "Специалист по шифрованию хранилища ключей" некоторой учетной записи
Этот шаг гарантирует, что вы сможете создать ключи шифрования.
- Перейдите к хранилищу ключей и выберите элемент Управление доступом (IAM) в области слева.
- В разделе Предоставить доступ к этому ресурсу выберите элемент Добавление назначения ролей.
- Выполните поиск по запросу Специалист по шифрованию хранилища ключей и выберите соответствующий результат.
- В разделе Члены выберите элемент Пользователь, группа или субъект-служба.
- Выберите элемент Члены и найдите свою учетную запись пользователя.
- Выберите Проверить и назначить.
Клиент создает ключ шифрования
Чтобы создать ключ шифрования, учетной записи пользователя необходимо назначить роль специалиста по шифрованию хранилища ключей или другую роль, которая разрешает создание ключа.
- На странице свойств хранилища ключей выберите элемент Ключи.
- Выберите Создать/импортировать.
- На экране создания ключа укажите имя ключа. Оставьте другие значения по умолчанию.
- Нажмите кнопку создания.
- Скопируйте URI ключа.
Клиент предоставляет приложению поставщика службы доступ к хранилищу ключей
Назначьте роль Azure RBAC Пользователь службы шифрования хранилища ключей зарегистрированному приложению поставщика службы, чтобы предоставить доступ к хранилищу ключей.
- Перейдите к хранилищу ключей и выберите элемент Управление доступом (IAM) в области слева.
- В разделе Предоставить доступ к этому ресурсу выберите элемент Добавление назначения ролей.
- Выполните поиск по запросу шифрование службы шифрования Key Vault и выберите соответствующий результат.
- В разделе Члены выберите элемент Пользователь, группа или субъект-служба.
- Выберите элемент Члены и найдите имя установленного приложения, полученного от поставщика службы.
- Выберите Проверить и назначить.
Теперь вы можете настроить ключи, управляемые клиентом, с помощью URI хранилища ключей и ключа.
Создание учетной записи Azure Cosmos DB, зашифрованной ключом из другого клиента
До этого момента вы настроили мультитенантное приложение на клиенте поставщика услуг. Вы также установили приложение в клиенте клиента и настроили хранилище ключей и ключ клиента. Затем можно создать учетную запись Azure Cosmos DB в клиенте поставщика услуг и настроить ключи, управляемые клиентом, с ключом клиента.
При создании учетной записи Azure Cosmos DB с ключами, управляемыми клиентом, необходимо убедиться, что у него есть доступ к ключам, используемым клиентом. В сценариях с одним клиентом можно предоставить прямой доступ к хранилищу ключей субъекту Azure Cosmos DB или использовать определенное управляемое удостоверение. В сценарии с несколькими клиентами мы больше не можем зависеть от прямого доступа к хранилищу ключей, так как он находится в другом клиенте, управляемом клиентом. Это ограничение объясняется тем, что в предыдущих разделах мы создали кросстенантное приложение и зарегистрировали управляемое удостоверение внутри приложения, чтобы предоставить ему доступ к хранилищу ключей клиента. Это управляемое удостоверение, в сочетании с идентификатором приложения между клиентами, — это то, что мы будем использовать при создании учетной записи CMK Azure Cosmos DB между клиентами. Дополнительные сведения см. в разделе " Этап 3. Поставщик услуг шифрует данные в ресурсе Azure с помощью раздела, управляемого клиентом" этой статьи.
Всякий раз, когда новая версия ключа доступна в хранилище ключей, она будет автоматически обновлена в учетной записи Azure Cosmos DB.
Использование шаблонов JSON в Azure Resource Manager
Разверните шаблон ARM со следующими параметрами:
Примечание.
Если вы воссоздаете этот пример в одном из шаблонов Azure Resource Manager, используйте этот пример apiVersion
2022-05-15
.
Параметр | Описание | Пример значения |
---|---|---|
keyVaultKeyUri |
Идентификатор ключа, управляемого клиентом, который находится в хранилище ключей поставщика услуг. | https://my-vault.vault.azure.com/keys/my-key |
identity |
Объект, указывающий, что управляемое удостоверение должно быть назначено учетной записи Azure Cosmos DB. | "identity":{"type":"UserAssigned","userAssignedIdentities":{"/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourcegroups/my-resource-group/providers/Microsoft.ManagedIdentity/userAssignedIdentities/my-identity":{}}} |
defaultIdentity |
Сочетание идентификатора ресурса управляемого удостоверения и идентификатора приложения Microsoft Entra с несколькими клиентами. | UserAssignedIdentity=/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourcegroups/my-resource-group/providers/Microsoft.ManagedIdentity/userAssignedIdentities/my-identity&FederatedClientId=aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e |
Ниже приведен пример сегмента шаблона с тремя параметрами, настроенными:
{
"kind": "GlobalDocumentDB",
"location": "East US 2",
"identity": {
"type": "UserAssigned",
"userAssignedIdentities": {
"/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourcegroups/my-resource-group/providers/Microsoft.ManagedIdentity/userAssignedIdentities/my-identity": {}
}
},
"properties": {
"locations": [
{
"locationName": "East US 2",
"failoverPriority": 0,
"isZoneRedundant": false
}
],
"databaseAccountOfferType": "Standard",
"keyVaultKeyUri": "https://my-vault.vault.azure.com/keys/my-key",
"defaultIdentity": "UserAssignedIdentity=/subscriptions/aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e/resourcegroups/my-resource-group/providers/Microsoft.ManagedIdentity/userAssignedIdentities/my-identity&FederatedClientId=aaaa0a0a-bb1b-cc2c-dd3d-eeeeee4e4e4e"
}
}
Внимание
Эта функция еще не поддерживается в Azure PowerShell, Azure CLI или портал Azure.
Вы не можете настроить ключи, управляемые клиентом, с определенной версией ключа при создании новой учетной записи Azure Cosmos DB. Сам ключ должен быть передан без версий и без конечных обратных косых клавиш.
Чтобы отменить или отключить ключи, управляемые клиентом, см . инструкции по настройке ключей, управляемых клиентом, для учетной записи Azure Cosmos DB с помощью Azure Key Vault.