使用容器生成 Azure Sphere 应用

重要

这是 Azure Sphere(旧版)文档。 Azure Sphere(旧版)将于 2027 年 9 月 27 日停用,用户此时必须迁移到 Azure Sphere(集成)。 使用位于 TOC 上方的版本选择器查看 Azure Sphere(集成)文档。

注意

本主题介绍如何使用适用于 Windows 的 Docker Desktop 在容器中生成 Azure Sphere 应用程序。 若要在 Linux 上的 Docker 容器中生成应用,可以从 Microsoft 工件注册表 或 MAR 使用相同的 azurespheresdk 容器(也称为Microsoft容器注册表或 MCR)。

安装 Docker Desktop

可以使用 Docker 运行预装了 Azure Sphere SDK 的独立 Linux 容器。 此映像还可以用作你自己的部署的基础。 映像标记是指它包含的 SDK 版本。

在下载并运行 Docker 容器之前,必须在 WindowsLinux 上安装 Docker Desktop。

安装适用于 Windows 的 Docker Desktop 后,请确保启用 Hyper-V 和容器 Windows 功能。 安装后可能需要重新启动。

安装后,从 Windows 开始菜单或添加到桌面的快捷图标启动 Docker Desktop。

Linux 是 Windows 上的 Docker Desktop 的默认容器类型。 Azure Sphere 使用 Linux 容器。 要运行 Linux 容器,需要确保 Docker 面向的是正确的守护程序。 若要验证 Linux 是否为当前默认类型的容器,请右键单击系统托盘中的 Docker 鲸鱼图标。 如果看到 “切换到 Windows 容器”,则表示你已面向 Linux 守护程序。 如果使用的是 Windows 容器,可以在系统托盘中右键单击 Docker 鲸鱼图标时,从操作菜单中选择“切换到 Linux 容器”来切换。 有关详细信息,请参阅在 Windows 容器和 Linux 容器之间切换

注意

等待 Docker Desktop 鲸鱼图标动画停止。 图标可能位于隐藏的“通知”区域中。 将鼠标悬停在图标上以查看 Docker Desktop 状态。

使用 Azure Sphere SDK 生成环境容器生成示例应用

可以通过输入容器并发出命令以交互方式使用容器;但是,捕获在 Docker 可用于基于原始 Azure Sphere 映像生成自定义映像的文件中生成应用程序所需的步骤更为高效。 这可确保生成过程可重复且一致。 默认情况下,此文件必须命名为 Dockerfile,并且位于运行 docker 命令的$PATH中。

以下步骤概述了如何创建用于生成 Azure Sphere 示例的 Dockerfile 说明。 可以根据自己的需求调整这些步骤。

  1. 基于 mcr.microsoft.com/azurespheresdk 容器创建新容器。

  2. 从 GitHub 克隆 Azure Sphere 示例存储库。

  3. 创建一个目录,用于在生成示例时将其存储在其中。

  4. 创建环境变量以指定要生成的示例。

  5. 运行 CMake 以生成示例并将其放置在指定的目录中。

创建用于生成示例的 Dockerfile

若要基于 Azure Sphere 映像生成 Docker 映像,但具有自定义生成功能,请使用以下 Docker 说明创建文本文件(不含文件扩展名):

FROM mcr.microsoft.com/azurespheresdk AS azsphere-samples-repo

RUN git clone https://github.com/Azure/azure-sphere-samples.git

FROM azsphere-samples-repo AS azsphere-sampleapp-build

RUN mkdir /build
WORKDIR /build

ENV sample=HelloWorld/HelloWorld_HighLevelApp

CMD cmake -G "Ninja" \
-DCMAKE_TOOLCHAIN_FILE="/opt/azurespheresdk/CMakeFiles/AzureSphereToolchain.cmake" \
-DAZURE_SPHERE_TARGET_API_SET="latest-lts" \
-DCMAKE_BUILD_TYPE="Debug" \
/azure-sphere-samples/Samples/${sample} && \
ninja

此文件使用 ENV 环境变量指定要生成的示例。 设置 ENV 的新值以生成不同于 HelloWorld/HelloWorld_HighLevelApp 的示例。

有关 Dockerfile 说明的更多详细信息,请参阅 Dockerfile 说明的逐行讨论。

使用 Dockerfile 生成默认示例应用

使用自定义 Dockerfile 生成示例应用需要三个步骤:

  1. 使用命令行接口(如 PowerShell、Windows 命令提示符或 Linux 命令行界面)从 Dockerfile 生成映像:

    docker build --target azsphere-sampleapp-build --tag azsphere-sampleapp-build .
    
    

    --target 选项指定要使用多阶段生成的哪个部分。 该 --tag 选项指定映像的名称,并且必须仅小写。 Docker 映像必须始终仅使用小写字母。 如果未指定名称 --tag,则图像将具有一个 12 位数字,该数字不容易使用。 不要忘记命令结尾的句点。 可以使用命令列出图像 docker images

    Docker 将基于名为“Dockerfile”的文件生成名为 azsphere-sampleapp-build 的映像。 如果 Dockerfile 命名为其他名称,请使用 --file 该选项指定名称。

  2. 使用 --name 选项为容器提供更简单的名称。 该run命令将输入容器并生成 ENV 环境变量指定的示例。 使用命令行接口输入以下命令:

    docker run --name hello_hl azsphere-sampleapp-build
    

    将生成示例应用(HelloWorld/HelloWorld_HighLevelApp),并将其放置在 /build 容器内的目录中。 容器运行完成后,它将退出并返回到命令行接口。

    注意

    此命令无需任何交互即可生成应用,并在生成完成后退出容器。 退出后容器仍处于活动状态。 这是因为未指定 -it--rm 选项。 只要 Docker Desktop 正在运行,就可以在容器上再次使用该 docker run 命令,而无需重新生成它。

  3. 将生成的结果从容器内部复制到主机环境。 使用命令行接口输入以下命令:

    docker cp hello_hl:/build .
    

    此命令将hello_h1容器中目录的内容/build复制到发出命令的主机上的目录。 该 /build 目录被指定为要编译该示例的工作目录(WORKDIR)。 请注意,你仍在容器外部,但使用 docker cp 命令向容器发出命令。 不要忘记命令结尾的句点。

使用自定义 Dockerfile 生成其他示例

若要生成其他示例,例如 GPIO 示例,请提供 GPIO 示例的路径。

docker run --name gpio_hl --env sample=GPIO/GPIO_HighLevelApp azsphere-sampleapp-build

生成完成后,将结果从容器内部复制到主机环境:

docker cp gpio_hl:/build .

不要忘记命令结尾的句点。

将包复制到主机环境后,可以使用 Windows 或 Linux 中的 Azure Sphere CLI 命令部署应用程序。 有关详细信息,请参阅 部署应用程序

不支持通过 USB 从容器进行设备交互。

Dockerfile 指令的逐行讨论

下面介绍了在创建用于生成示例的 Dockerfile 中创建的 Dockerfile 的每个部分。

准备多个生成

FROM mcr.microsoft.com/azurespheresdk AS azsphere-samples-repo

此行基于原始 microsoft.com/azurespheresdk 容器设置新的生成 azsphere-samples-repo

下载 Azure Sphere 示例

RUN git clone https://github.com/Azure/azure-sphere-samples.git

此行克隆 Azure Sphere 示例存储库中的所有示例。

添加另一个可定向的多阶段生成

FROM azsphere-samples-repo AS azsphere-sampleapp-build

此行基于 azsphere-samples-repo 生成添加新生成。

在容器内设置工作目录

RUN mkdir /build
WORKDIR /build

这些行创建新的工作目录。

创建默认环境变量以指定示例

ENV sample=HelloWorld/HelloWorld_HighLevelApp

此行创建一个环境变量,用于指定要生成的示例。 在本例中,它是HelloWorld_HighLevelApp示例。 可以重写环境变量以指定任何示例名称和路径。

运行 CMake 和 Ninja 以生成包

CMD cmake -G "Ninja" \
-DCMAKE_TOOLCHAIN_FILE="/opt/azurespheresdk/CMakeFiles/AzureSphereToolchain.cmake" \
-DAZURE_SPHERE_TARGET_API_SET="latest-lts" \
-DCMAKE_BUILD_TYPE="Debug" \
/azure-sphere-samples/Samples/${sample} && \
ninja

本部分使用 CMake 指定调用 Ninja 生成包时使用的参数。

生成完成后,容器将停止运行。

Docker 提示

这些提示可能有助于更有效地使用 Docker。

使用 docker run 命令以交互方式浏览基本容器

使用命令行接口输入以下命令:

docker run --rm -it mcr.microsoft.com/azurespheresdk

在此示例中, mcr.microsoft.com/azurespheresdk 是容器从中创建的映像的名称。 请注意,该 --rm 选项在运行后关闭容器,该 -it 选项指定对容器的交互式访问。

Azure Sphere SDK 生成环境 Docker 容器由Microsoft 工件注册表(MAR)提供,可供公众使用。

如果容器已在本地计算机上,则不会再次下载该容器。

下载和设置可能需要几分钟时间。 生成环境包括使用 Azure Sphere Linux SDK 生成包所需的所有内容。

命令 run 完成后,命令提示符将更改为“#”符号。 现在,你位于基于 Linux 的 Docker 容器中。 键入 ls 会显示容器中的当前 Linux 目录,类似于以下列表:

bin   cmake-3.14.5-Linux-x86_64  etc   lib    makeazsphere.sh  mnt    opt   root  sbin  sys  usr
boot  dev                        home  lib64  media            ninja  proc  run   srv   tmp  var

键入 exit 以离开容器。 容器将不再可供你使用,需要使用以下命令再次创建它:

docker run --rm -it mcr.microsoft.com/azurespheresdk

如果不使用该 --rm 选项,退出时不会删除容器。

容器标识

生成新容器时,它将具有一个 ID,例如 a250ade97090 (你的 ID 将有所不同)。 对于许多 Docker 命令,必须使用 ID 而不是 microsoft.com/azurespheresdk 地址。

下面是有关系统上容器的基本信息的典型列表,使用以下命令:

docker ps --all

结果如下所示:

CONTAINER ID        IMAGE                   COMMAND             CREATED             STATUS              PORTS               NAMES
a250ade97090        microsoft.com/azurespheresdk   "/bin/bash"         15 minutes ago      Up 9 seconds                            pedantic_kilby

你的 ID 将有所不同。 请注意,Docker 为容器所有者构成随机名称。 请注意,在此示例中,只有一个容器。

在容器内工作

如果要在不使用 run 命令的情况下在计算机上的容器内工作,请键入以下内容,将 exec 命令与容器 ID 和要运行的容器中的脚本一起使用(/bin/bash):

docker exec -t a250ade97090 /bin/bash

命令提示符将更改为“#”符号。 现在,你位于基于 Linux 的 Docker 容器中。 键入 ls 会显示容器中的当前 Linux 目录:

bin   cmake-3.14.5-Linux-x86_64  etc   lib    makeazsphere.sh  mnt    opt   root  sbin  sys  usr
boot  dev                        home  lib64  media            ninja  proc  run   srv   tmp  var

若要离开容器,请键入 exit 命令。

Azure Sphere SDK 生成容器限制

Azure Sphere SDK 生成容器旨在仅生成 Azure Sphere 包。 它不适用于运行 Azure Sphere CLI 命令、恢复或旁加载设备或调试。 容器无权访问 USB 函数。

Docker Linux 容器限制

Docker Linux 容器与完全安装 Linux 不同。 例如,无法在 Docker Linux 容器中运行 Linux GUI 应用程序。

使用多阶段生成容器减少依赖项

Docker 多阶段生成功能允许在 Dockerfile 中使用多个 FROM 语句来减少依赖项。 每个 FROM 指令都可以使用不同的基础,每个指令都开始生成的新阶段。

有关 Docker 多阶段生成的详细信息,请参阅 “使用多阶段生成”。

Docker 建议使用多阶段生成作为最佳做法。 有关 Docker 最佳做法的详细信息,请参阅 Dockerfile 最佳做法简介指南。

使用 AS 参数向阶段添加有意义的名称

默认情况下,阶段未命名,但具有 ID 号。 通过追加 AS 和名称,可以将有意义的名称添加到阶段,使 Dockerfile 更易于阅读。 例如:

FROM mcr.microsoft.com/azurespheresdk AS azsphere-samples-repo

有关在多阶段命令中使用 AS 参数的详细信息,请参阅 命名生成阶段

以有意义的名称构建目标作为最佳做法

生成目标时,可以使用 --tag 选项为其指定有意义的名称。 有意义的名称非常有用。 例如:

docker build --target azsphere-sampleapp-build --tag azsphere-sampleapp-build .

有关将名称与 Docker 生成 命令配合使用的详细信息,请参阅 Docker 生成参考