8.9 KiB
layout | page_title |
---|---|
docs | Amazon AMI Builder (chroot) |
AMI Builder (chroot)
Type: amazon-chroot
The amazon-chroot
builder is able to create Amazon AMIs backed by
an EBS volume as the root device. For more information on the difference
between instance storage and EBS-backed instances, see the
"storage for the root device" section in the EC2 documentation.
The difference between this builder and the amazon-ebs
builder is that
this builder is able to build an EBS-backed AMI without launching a new
EC2 instance. This can dramatically speed up AMI builds for organizations
who need the extra fast build.
This is an advanced builder. If you're just getting started with Packer, we recommend starting with the amazon-ebs builder, which is much easier to use.
The builder does not manage AMIs. Once it creates an AMI and stores it in your account, it is up to you to use, delete, etc. the AMI.
How Does it Work?
This builder works by creating a new EBS volume from an existing source AMI and attaching it into an already-running EC2 instance. One attached, a chroot is used to provision the system within that volume. After provisioning, the volume is detached, snapshotted, and an AMI is made.
Using this process, minutes can be shaved off the AMI creation process because a new EC2 instance doesn't need to be launched.
There are some restrictions, however. The host EC2 instance where the volume is attached to must be a similar system (generally the same OS version, kernel versions, etc.) as the AMI being built. Additionally, this process is much more expensive because the EC2 instance must be kept running persistently in order to build AMIs, whereas the other AMI builders start instances on-demand to build AMIs as needed.
Configuration Reference
There are many configuration options available for the builder. They are segmented below into two categories: required and optional parameters. Within each category, the available configuration keys are alphabetized.
Required:
-
access_key
(string) - The access key used to communicate with AWS. If not specified, Packer will attempt to read this from environmental variablesAWS_ACCESS_KEY_ID
orAWS_ACCESS_KEY
(in that order). If the environmental variables aren't set and Packer is running on an EC2 instance, Packer will check the instance metadata for IAM role keys. -
ami_name
(string) - The name of the resulting AMI that will appear when managing AMIs in the AWS console or via APIs. This must be unique. To help make this unique, use a function liketimestamp
(see configuration templates for more info) -
secret_key
(string) - The secret key used to communicate with AWS. If not specified, Packer will attempt to read this from environmental variablesAWS_SECRET_ACCESS_KEY
orAWS_SECRET_KEY
(in that order). If the environmental variables aren't set and Packer is running on an EC2 instance, Packer will check the instance metadata for IAM role keys. -
source_ami
(string) - The source AMI whose root volume will be copied and provisioned on the currently running instance. This must be an EBS-backed AMI with a root volume snapshot that you have access to.
Optional:
-
ami_description
(string) - The description to set for the resulting AMI(s). By default this description is empty. -
ami_groups
(array of string) - A list of groups that have access to launch the resulting AMI(s). By default no groups have permission to launch the AMI. -
ami_product_codes
(array of string) - A list of product codes to associate with the AMI. By default no product codes are associated with the AMI. -
ami_regions
(array of string) - A list of regions to copy the AMI to. Tags and attributes are copied along with the AMI. AMI copying takes time depending on the size of the AMI, but will generally take many minutes. -
ami_users
(array of string) - A list of account IDs that have access to launch the resulting AMI(s). By default no additional users other than the user creating the AMI has permissions to launch it. -
chroot_mounts
(list of list of strings) - This is a list of additional devices to mount into the chroot environment. This configuration parameter requires some additional documentation which is in the "Chroot Mounts" section below. Please read that section for more information on how to use this. -
copy_files
(list of strings) - Paths to files on the running EC2 instance that will be copied into the chroot environment prior to provisioning. This is useful, for example, to copy/etc/resolv.conf
so that DNS lookups work. -
device_path
(string) - The path to the device where the root volume of the source AMI will be attached. This defaults to "" (empty string), which forces Packer to find an open device automatically. -
command_wrapper
(string) - How to run shell commands. This defaults to "{{.Command}}". This may be useful to set if you want to set environmental variables or perhaps run it withsudo
or so on. This is a configuration template where the.Command
variable is replaced with the command to be run.. -
mount_path
(string) - The path where the volume will be mounted. This is where the chroot environment will be. This defaults topacker-amazon-chroot-volumes/{{.Device}}
. This is a configuration template where the.Device
variable is replaced with the name of the device where the volume is attached. -
tags
(object of key/value strings) - Tags applied to the AMI.
Basic Example
Here is a basic example. It is completely valid except for the access keys:
{ "type": "amazon-chroot", "access_key": "YOUR KEY HERE", "secret_key": "YOUR SECRET KEY HERE", "source_ami": "ami-e81d5881", "ami_name": "packer-amazon-chroot {{timestamp}}" }
Chroot Mounts
The chroot_mounts
configuration can be used to mount additional devices
within the chroot. By default, the following additional mounts are added
into the chroot by Packer:
/proc
(proc)/sys
(sysfs)/dev
(bind to real/dev
)/dev/pts
(devpts)/proc/sys/fs/binfmt_misc
(binfmt_misc)
These default mounts are usually good enough for anyone and are sane
defaults. However, if you want to change or add the mount points, you may
using the chroot_mounts
configuration. Here is an example configuration:
{ "chroot_mounts": [ ["proc", "proc", "/proc"], ["bind", "/dev", "/dev"] ] }
chroot_mounts
is a list of a 3-tuples of strings. The three components
of the 3-tuple, in order, are:
-
The filesystem type. If this is "bind", then Packer will properly bind the filesystem to another mount point.
-
The source device.
-
The mount directory.
Parallelism
A quick note on parallelism: it is perfectly safe to run multiple
separate Packer processes with the amazon-chroot
builder on the same
EC2 instance. In fact, this is recommended as a way to push the most performance
out of your AMI builds.
Packer properly obtains a process lock for the parallelism-sensitive parts of its internals such as finding an available device.
Gotchas
One of the difficulties with using the chroot builder is that your provisioning scripts must not leave any processes running or packer will be unable to unmount the filesystem.
For debian based distributions you can setup a policy-rc.d file which will prevent packages installed by your provisioners from starting services:
{ "type": "shell", "inline": [ "echo '#!/bin/sh' > /usr/sbin/policy-rc.d", "echo 'exit 101' >> /usr/sbin/policy-rc.d", "chmod a+x /usr/sbin/policy-rc.d" ] }, # ... { "type": "shell", "inline": [ "rm -f /usr/sbin/policy-rc.d" ] }
Using an IAM Instance Profile
If AWS keys are not specified in the template or through environment variables Packer will use credentials provided by the instance's IAM profile, if it has one.
The following policy document provides the minimal set permissions necessary for Packer to work:
{ "Statement": [{ "Effect": "Allow", "Action" : [ "ec2:AttachVolume", "ec2:CreateVolume", "ec2:DeleteVolume", "ec2:DescribeVolumes", "ec2:DetachVolume", "ec2:DescribeInstances", "ec2:CreateSnapshot", "ec2:DeleteSnapshot", "ec2:DescribeSnapshots", "ec2:DescribeImages", "ec2:RegisterImage", "ec2:CreateTags" ], "Resource" : "*" }] }
Depending on what setting you use the following Actions might have to be allowed as well:
ec2:ModifyImageAttribute
when usingami_description