Microsoft Azure 上的自定义数据和 Cloud-Init

自定义数据是什么?

客户经常询问如何才能在配置 Microsoft Azure 虚拟机时插入脚本或其他元数据。在其他云中,这个概念通常称为用户数据。Microsoft Azure 中也有一项类似的功能,我们称之为自定义数据

自定义数据随其他配置信息(例如新的主机名、用户名、密码、证书和密钥等)一起发送到 VM。这类数据经过 base64 编码后传递给 Azure API。在 Windows 上,自定义数据最终作为二进制文件保存在 %SYSTEMDRIVE%\AzureData\CustomData.bin 中。在 Linux 上,自定义数据在创建虚拟机时被复制到 /var/lib/waagent 目录的 ovf-env.xml 文件。为了方便起见,更高版本的 Microsoft Azure Linux 代理同样会将 base64 编码后的数据复制到 /var/lib/waagent/CustomData

Cloud-Init 是什么?

目前,只有 Microsoft Azure 库中的 Ubuntu 镜像预安装了 cloud-init,并设置为处理在虚拟机创建期间发送的自定义数据。这意味着,对于 Ubuntu,您可以借助 cloud-init 配置文件使用自定义数据对 VM 进行创建,或只发送 cloud-init 将在创建时执行的脚本。有关详细信息,请参阅 cloud-init 文档

如果镜像上不能使用 cloud-init,您仍可以使用预安装脚本时提供的自定义数据或者系统上可以读取数据的其他工具。在这种情况下,可能会安装可在自定义数据中通过 %SYSTEMDRIVE%\AzureData\CustomData.bin (Windows) 或 /var/lib/waagent/ovf-env.xml (Linux) 文件读取的脚本,启动时运行该脚本并解码,使其作用于自定义数据。安装脚本后,可以取消配置 WindowsLinux 镜像,捕获此镜像以供重复使用。

工作原理

目前,向 IaaS VM 插入自定义数据最简单的方式就是使用 Windows Azure 命令行工具。目前,Microsoft Azure Powershell cmdlet 尚不支持此功能,但很快就会在即将发行的版本中推出。

自 CLI 工具 0.7.5 版起,出现了一个称为 --custom-data 的新参数。此参数将文件名视作参数,然后 CLI 工具会使用 base64 对文件内容进行编码,并将其与配置信息一起发送。此处唯一的限制就是文件必须小于 64KB,否则 Azure API 将不会接受请求。

以下是如何向 Ubuntu Linux VM 准备和传递自定义数据的简单示例:

在此示例中,custom-data.txt 可以是 cloud-init 配置文件,也可以只是一个 shell 脚本(只要以 #! 开头,cloud-init 就会执行)。试试看吧。

其他参考:

https://msdn.microsoft.com/en-us/library/windowsazure/jj157186.aspx

本文翻译自:https://blogs.msdn.com/b/windowsazure/archive/2014/04/21/custom-data-and-cloud-init-on-windows-azure.aspx