packer-cn/builder/azure/arm
Christopher Boumenot c7018a00c8 Add support for Windows to Azure.
This is last merge that will happen from the github.com/Azure/packer-Azure
repository.  All development is being over to this repository.

The biggest change in this merge is support for Windows.  There are a few other
fixes as well.

 * If the user cancels the build, clean up any resources.
 * Output a reasonable build artifact.
 * Log requests and responses with Azure.
 * Support for US Government and the China clouds.
 * Support interrupting long running tasks.
 * Allow the user to set the image version.
 * Device login support.
2016-05-05 13:40:17 -07:00
..
README.md Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
artifact.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
artifact_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
authenticate.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
authenticate_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
azure_client.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
builder.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
builder_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
capture_template.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
capture_template_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
config.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
config_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
deployment_factory.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
deployment_factory_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
deployment_poller.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
deployment_poller_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
inspector.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
openssh_key_pair.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
openssh_key_pair_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_capture_image.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_capture_image_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_create_resource_group.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_create_resource_group_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_delete_os_disk.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_delete_os_disk_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_delete_resource_group.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_delete_resource_group_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_deploy_template.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_deploy_template_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_get_certificate.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_get_certificate_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_get_ip_address.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_get_ip_address_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_get_os_disk.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_get_os_disk_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_power_off_compute.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_power_off_compute_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_set_certificate.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_set_certificate_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_validate_template.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
step_validate_template_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
template.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
template_parameters.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
template_parameters_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
tempname.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00
tempname_test.go Add support for Windows to Azure. 2016-05-05 13:40:17 -07:00

README.md

packer-azure-arm

The ARM flavor of packer-azure utilizes the Azure Resource Manager APIs. Please see the overview for more information about ARM as well as the benefit of ARM.

Device Login vs. Service Principal Name (SPN)

There are two ways to get started with packer-azure. The simplest is device login, and only requires a Subscription ID. Device login is only supported for Linux based VMs. The second is the use of an SPN. We recommend the device login approach for those who are first time users, and just want to ''kick the tires.'' We recommend the SPN approach if you intend to automate Packer, or you are deploying Windows VMs.

Device Login

A sample template for device login is show below. There are three pieces of information you must provide to enable device login mode.

  1. SubscriptionID
  2. Resource Group - parent resource group that Packer uses to build an image.
  3. Storage Account - storage account where the image will be placed.

Device login mode is enabled by not setting client_id, client_secret, and tenant_id.

The device login flow asks that you open a web browser, navigate to http://aka.ms/devicelogin, and input the supplied code. This authorizes the Packer for Azure application to act on your behalf. An OAuth token will be created, and stored in the user's home directory (~/.azure/packer/oauth-TenantID.json, and TenantID will be replaced with the actual Tenant ID). This token is used if it exists, and refreshed as necessary.

{
    "variables": {
        "sid": "your_subscription_id",
        "rgn": "your_resource_group",
        "sa": "your_storage_account"
    },
    "builders": [
        {
            "type": "azure-arm",

            "subscription_id": "{{user `sid`}}",

            "resource_group_name": "{{user `rgn`}}",
            "storage_account": "{{user `sa`}}",

            "capture_container_name": "images",
            "capture_name_prefix": "packer",

            "os_type": "Linux",
            "image_publisher": "Canonical",
            "image_offer": "UbuntuServer",
            "image_sku": "14.04.3-LTS",

            "location": "South Central US",
            "vm_size": "Standard_A2"
        }
    ],
    "provisioners": [
        {
            "execute_command": "chmod +x {{ .Path }}; {{ .Vars }} sudo -E sh '{{ .Path }}'",
            "inline": [
                "apt-get update",
                "apt-get upgrade -y",

                "/usr/sbin/waagent -force -deprovision+user && export HISTSIZE=0 && sync"
            ],
            "inline_shebang": "/bin/sh -x",
            "type": "shell"
        }
    ]
}

Service Principal Name

The ARM APIs use OAUTH to authenticate, and requires an SPN. The following articles are a good starting points for creating a new SPN.

There are three (four in the case of Windows) pieces of configuration you need to note after creating an SPN.

  1. Client ID (aka Service Principal ID)
  2. Client Secret (aka Service Principal generated key)
  3. Client Tenant (aka Azure Active Directory tenant that owns the Service Principal)
  4. Object ID (Windows only) - a certificate is used to authenticate WinRM access, and the certificate is injected into the VM using Azure Key Vault. Access to the key vault is protected by an ACL associated with the SPN's ObjectID. Linux does not need nor use a key vault, so there's no need to know the ObjectID.

You will also need the following.

  1. Subscription ID
  2. Resource Group
  3. Storage Account

Resource Group is where your storage account is located, and Storage Account is where the created packer image will be stored.

The Service Principal has been tested with the following permissions. Please review the document for the built in roles for more details.

  • Owner

NOTE: the Owner role is too powerful, and more explicit set of roles is TBD. Issue #183 is tracking this work. Permissions can be scoped to a specific resource group to further limit access.

Sample Ubuntu

The following is a sample Packer template for use with the Packer Azure for ARM builder.

{
    "variables": {
        "cid": "your_client_id",
        "cst": "your_client_secret",
        "tid": "your_client_tenant",
        "sid": "your_subscription_id",

        "rgn": "your_resource_group",
        "sa": "your_storage_account"
    },
    "builders": [
        {
            "type": "azure-arm",

            "client_id": "{{user `cid`}}",
            "client_secret": "{{user `cst`}}",
            "subscription_id": "{{user `sid`}}",
            "tenant_id": "{{user `tid`}}",

            "resource_group_name": "{{user `rgn`}}",
            "storage_account": "{{user `sa`}}",

            "capture_container_name": "images",
            "capture_name_prefix": "packer",

            "os_type": "Linux",
            "image_publisher": "Canonical",
            "image_offer": "UbuntuServer",
            "image_sku": "14.04.3-LTS",

            "location": "South Central US",

            "vm_size": "Standard_A2"
        }
    ],
    "provisioners": [
        {
            "execute_command": "chmod +x {{ .Path }}; {{ .Vars }} sudo -E sh '{{ .Path }}'",
            "inline": [
                "apt-get update",
                "apt-get upgrade -y",

                "/usr/sbin/waagent -force -deprovision+user && export HISTSIZE=0 && sync"
            ],
            "inline_shebang": "/bin/sh -x",
            "type": "shell"
        }
    ]
}

Using the above template, Packer would be invoked as follows.

NOTE: the following variables must be changed based on your subscription. These values are just dummy values, but they match format of expected, e.g. if the value is a GUID the sample is a GUID.

packer build^
  -var cid="593c4dc4-9cd7-49af-9fe0-1ea5055ac1e4"^
  -var cst="GbzJfsfrVkqL/TLfZY8TXA=="^
  -var sid="ce323e74-56fc-4bd6-aa18-83b6dc262748"^
  -var tid="da3847b4-8e69-40bd-a2c2-41da6982c5e2"^
  -var rgn="My Resource Group"^
  -var sa="mystorageaccount"^
  c:\packer\ubuntu_14_LTS.json

Please see the config_sameples/arm directory for more examples of usage.