aboutsummaryrefslogtreecommitdiffhomepage
path: root/ubuntu16.04-onbuild
diff options
context:
space:
mode:
authorWilliam Yeh <william.pjyeh@gmail.com>2016-05-09 16:34:32 +0800
committerWilliam Yeh <william.pjyeh@gmail.com>2016-05-10 17:17:33 +0800
commit97d48efeb67f4f7566752625ad3ce233f31985be (patch)
tree20ce7984d99bf5f6b770fce81384790027723517 /ubuntu16.04-onbuild
parentb314855954aa117b1294056891d16f43a6b1b9d0 (diff)
downloaddocker-ansible-97d48efeb67f4f7566752625ad3ce233f31985be.tar.gz
docker-ansible-97d48efeb67f4f7566752625ad3ce233f31985be.tar.zst
docker-ansible-97d48efeb67f4f7566752625ad3ce233f31985be.zip
Add: support for Ubuntu 16.04 LTS (Xenial).
Fix: 1. OS-level packages `libffi-dev` and `libssl-dev`/`openssl-dev` should be installed explicitly since Ansible 2.0.2.0(???). 2. Python package cffi should be installed explicitly since Ansible 2.0.2.0(???). 3. add '--fix-missing' for apt. @see https://github.com/boxcutter/ubuntu/issues/62 @see https://github.com/pyca/cryptography/issues/2280
Diffstat (limited to 'ubuntu16.04-onbuild')
-rw-r--r--ubuntu16.04-onbuild/Dockerfile45
-rwxr-xr-xubuntu16.04-onbuild/ansible-playbook-wrapper49
2 files changed, 94 insertions, 0 deletions
diff --git a/ubuntu16.04-onbuild/Dockerfile b/ubuntu16.04-onbuild/Dockerfile
new file mode 100644
index 0000000..cc28d8c
--- /dev/null
+++ b/ubuntu16.04-onbuild/Dockerfile
@@ -0,0 +1,45 @@
1# Dockerfile for building Ansible image for Ubuntu 16.04 (Xenial), with as few additional software as possible.
2#
3# @see https://launchpad.net/~ansible/+archive/ubuntu/ansible
4#
5# Version 1.0
6#
7
8
9# pull base image
10FROM ubuntu:16.04
11
12MAINTAINER William Yeh <william.pjyeh@gmail.com>
13
14
15RUN DEBIAN_FRONTEND=noninteractive apt-get update && \
16 \
17 \
18 echo "===> Installing Ansible..." && \
19 apt-get install -y ansible && \
20 \
21 \
22 echo "===> Clean up..." && \
23 rm -rf /var/lib/apt/lists/* && \
24 \
25 \
26 echo "===> Adding hosts for convenience..." && \
27 echo 'localhost' > /etc/ansible/hosts
28
29
30COPY ansible-playbook-wrapper /usr/local/bin/
31
32ONBUILD RUN DEBIAN_FRONTEND=noninteractive apt-get update && \
33 echo "===> Updating TLS certificates..." && \
34 apt-get install -y openssl ca-certificates
35
36ONBUILD WORKDIR /tmp
37ONBUILD COPY . /tmp
38ONBUILD RUN \
39 echo "===> Diagnosis: host information..." && \
40 ansible -c local -m setup all
41
42
43
44# default command: display Ansible version
45CMD [ "ansible-playbook", "--version" ]
diff --git a/ubuntu16.04-onbuild/ansible-playbook-wrapper b/ubuntu16.04-onbuild/ansible-playbook-wrapper
new file mode 100755
index 0000000..0ba45e6
--- /dev/null
+++ b/ubuntu16.04-onbuild/ansible-playbook-wrapper
@@ -0,0 +1,49 @@
1#!/bin/sh
2#
3# Simple wrapper for executing ansible-galaxy and ansible-playbook
4# with local connection.
5#
6# USAGE:
7# ansible-playbook-wrapper [other ansible-playbook arguments]
8#
9# ENVIRONMENT VARIABLES:
10#
11# - REQUIREMENTS: requirements filename; default = "requirements.yml"
12# - PLAYBOOK: playbook filename; default = "playbook.yml"
13# - INVENTORY: inventory filename; default = "/etc/ansible/hosts"
14#
15
16
17#
18# install Galaxy roles, if any
19#
20
21if [ -z "$REQUIREMENTS" ]; then
22 REQUIREMENTS=requirements.yml
23fi
24
25if [ -f "$REQUIREMENTS" ]; then
26 ansible-galaxy install -r $REQUIREMENTS
27fi
28
29
30#
31# execute playbook
32#
33
34if [ -z "$PLAYBOOK" ]; then
35 PLAYBOOK=playbook.yml
36fi
37
38
39if [ -z "$INVENTORY" ]; then
40 exec ansible-playbook \
41 $PLAYBOOK \
42 --connection=local \
43 "$@"
44else
45 exec ansible-playbook \
46 -i $INVENTORY $PLAYBOOK \
47 --connection=local \
48 "$@"
49fi