summaryrefslogtreecommitdiffstats
path: root/packer/README.markdown
blob: 597e64b0d037672b3da9cc2edd13f55251f5155f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
# Open-O Project CI Packer

[Packer][1] is a tool for automatically creating VM and container images,
configuring them and post-processing them into standard output formats.

We build Open-O's CI images via Packer.

## Building

You'll need to [install Packer][2], of course.

Open-O's Packer configuration is divided into build-specific variables,
output-specific templates and a set of shared provisioning scripts. To do a
specific build, combine the template for the desired output artifact type with
a variable file. To build a new builder instance the following would be done:

```
packer build -var-file=vars/cloud-env.json -var-file=vars/centos.json templates/builder.json
```

**NOTE:** vars/cloud-env.json is a gitignored file as it contains private
information. There is a vars/cloud-env.json.example file that may be used as a
base for creating the one needed.

This would build a bootable image in the Open-O CI cloud environment.

From a high level, the builds:

-   Boot a specified base image in the cloud
-   Run a set of shell scripts, listed in the template's shell provisioner
    section, to do any configuration required by the builder.
-   Execute a shutdown of the running instance
-   Execute a 'nova image-create' operation against the shutdown instance.
-   Perform a 'nova delete' operation against the shutdown instance.

[1]: https://www.packer.io/
[2]: https://www.packer.io/intro/getting-started/setup.html