Skip to content

Latest commit

 

History

History
117 lines (73 loc) · 3.84 KB

README.md

File metadata and controls

117 lines (73 loc) · 3.84 KB

Packer

Set of example files for Packer on Azure.

Packer is commonly used to generate custom virtual machine images.

Images may be standalone resources, or versioned images stored in an Azure Compute Gallery (formerly known as Shared Image Gallery).

Authentication

There are a few ways to authenticate to Azure when running Packer. These examples show the differences and when each option is commonly used.

Authentication Type Description
interactive Interactive login
azure_cli_token Manually test image builds from your local system
managed_identity As above, but run on a config management server or in Cloud Shell
service_principal Suitable for production image creation CI/CD pipelines

All of the examples above will create the same Ubuntu 20.04 custom image.

Scenarios

Additional scenarios. The examples below authenticate using service principal variables and assume subscription level Contributor access.

Scenario Description
azure_compute_gallery Additional Azure Compute Gallery publishing step
image_to_image Use a custom image as the source and layer additional customisations
image_to_gallery As above, with additional Azure Compute Gallery publishing step
gallery_to_gallery As above, using a gallery image as the source

More to be added, e.g. Windows, cloud-init, Ansible, etc.

Raise an issue if there is a specific scenario that you would like to see.

Setup

Packer directory

Clone this repo so that you have the example files locally.

  1. Clone the repo

    The lab assumes you are in your home directory. (cd ~)

    git clone https://github.com/richeney/packer
  2. Change directory

    cd packer
  3. Set local defaults

    Setting local defaults will save typing --location <region> for each command. Set to your preferred location.

    az config set --local defaults.location=uksouth

    The examples use UK South as the primary region. Images are replicated to UK West.

Managed image resource group

Creating custom images with Packer requires an existing resource group for the resulting custom images.

You will need an resource group for your images.

az group create --name images

You can use a different name but you will have to edit the value for managed_image_resource_group_name in the files.

Build resource group

Optional.

Packer will create temporary resource groups for build artefacts if it has sufficient access. Therefore this resource group is only required if you a) you are using service principals and b) you need to be more selective with the the assigned access. See service principal for more info.

az group create --name packer

You can use a different name but you will have to edit the value for build_resource_group_name in the files.

Azure Compute Gallery

Run the following commands if you are using the Azure Compute Gallery examples.

  1. Create the gallery resource group

    az group create --name gallery
  2. Create the Azure Compute Gallery

    az sig create --gallery-name gallery --resource-group gallery
  3. Get the resource ID

    galleryId=$(az sig show --gallery-name gallery --resource-group gallery --query id --output tsv)

Links