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

边缘上的机密计算

适用于:IoT Edge 1.4 复选标记 IoT Edge 1.4

重要

IoT Edge 1.4 是受支持的版本。 如果你使用的是较低的版本,请参阅更新 IoT Edge

Azure IoT Edge 支持在设备上的安全 enclave 中运行的机密应用程序。 加密会为传输中的数据或静态数据提供安全性,但 enclave 会为正在使用的数据和工作负载提供安全性。 IoT Edge 支持将 Open Enclave 作为开发机密应用程序的标准。

安全性是物联网 (IoT) 的重要关注点,因为 IoT 设备通常位于外部世界,而不是在专用设施内受到保护。 这样的暴露会使设备面临篡改和伪造的风险,因为它们在物理上可由行为不端的人访问。 IoT Edge 设备甚至对信任和完整性有更多需求,因为它们允许敏感工作负载在边缘上运行。 与常见传感器和传动器不同,这些智能边缘设备可能会暴露以前仅在受保护的云或本地环境中运行的敏感工作负载。

IoT Edge 安全管理器解决了一部分的机密计算难题。 安全管理器使用硬件安全模块 (HSM) 来保护 IoT Edge 设备的标识工作负载和正在进行的进程。

机密计算的另一个方面是保护正在边缘上使用的数据。 受信任的执行环境 (TEE) 是处理器上的一种安全的隔离环境,有时称为“enclave”。 机密应用程序是在 enclave 中运行的应用程序。 由于 enclave 的性质,机密应用程序会受到保护,免遭主处理器或 TEE 中运行的其他应用的侵害。

IoT Edge 上的机密应用程序

机密应用程序在传输中以及在静态时是加密的,并且仅当要在受信任的执行环境内运行时才解密。 此标准适用于作为 IoT Edge 模块部署的机密应用程序。

开发人员创建机密应用程序并将其打包为 IoT Edge 模块。 应用程序在推送到容器注册表之前会进行加密。 在 IoT Edge 设备上启动该模块之前,应用程序将在整个 IoT Edge 部署过程中保持“已加密”状态。 机密应用程序一旦位于设备的 TEE 内就会进行解密,并且可以开始执行。

一个示意图,显示了在部署到安全的 enclave 之前,机密应用程序在 IoT Edge 模块内是加密的。

IoT Edge 上的机密应用程序是 Azure 机密计算的逻辑扩展。 也可将云中的安全 enclave 内运行的工作负载部署为在边缘的安全 enclave 内运行。

开放式 Enclave

Open Enclave SDK 是一个开源项目,可帮助开发人员为多个平台和环境创建机密应用程序。 Open Enclave SDK 在设备的受信任执行环境中运行,而 Open Enclave API 则充当 TEE 和非 TEE 处理环境之间的接口。

Open Enclave 支持多个硬件平台。 IoT Edge 对 enclave 的支持目前需要 Open Portable TEE 操作系统 (OP-TEE OS)。 若要了解详细信息,请参阅用于 OP-TEE OS 的Open Enclave SDK

Open Enclave 存储库还包含用于帮助开发人员入门的示例。 有关详细信息,请选择以下的介绍性文章之一:

硬件

目前,对于将机密应用程序部署为 IoT Edge 模块,Scalys 提供的 TrustBox 是制造商服务协议支持的唯一设备。 TrustBox 基于 TrustBox Edge 和 TrustBox EdgeXL 设备而构建,这两种设备均预加载了 Open Enclave SDK 和 Azure IoT Edge。

有关详细信息,请参阅 Getting started with Open Enclave for the Scalys TrustBox(开始为 Scalys TrustBox 使用 Open Enclave)。

开发和部署

当你准备好开发和部署机密应用程序时,用于 Visual Studio Code 的 Microsoft Open Enclave 扩展便可以提供帮助了。 可以使用 Linux 或 Windows 作为开发计算机,以便针对 TrustBox 开发模块。

后续步骤

了解如何开始使用用于 Visual Studio Code 的 Open Enclave 扩展开发作为 IoT Edge 模块的机密应用程序。