aboutsummaryrefslogtreecommitdiffhomepage
path: root/master-ubuntu14.04-onbuild/Dockerfile
diff options
context:
space:
mode:
authorWilliam Yeh <william.pjyeh@gmail.com>2015-12-15 06:38:42 +0800
committerWilliam Yeh <william.pjyeh@gmail.com>2015-12-15 12:00:31 +0800
commit930848e72e00c9f72fd4302e02dd1c7747696363 (patch)
tree776d96738371319b6eee8901eeaac0134eefa4f5 /master-ubuntu14.04-onbuild/Dockerfile
parenta8aa5c011bab589aef558768b5c91004d0c13fd0 (diff)
downloaddocker-ansible-930848e72e00c9f72fd4302e02dd1c7747696363.tar.gz
docker-ansible-930848e72e00c9f72fd4302e02dd1c7747696363.tar.zst
docker-ansible-930848e72e00c9f72fd4302e02dd1c7747696363.zip
Add: building from source tree.
Fix: systemd conflicts with new CentOS7 image; See https://forums.docker.com/t/yum-update-fails-for-centos-7-container/5060 Fix: ca-certificates should be installed in Debian 7 for `git clone` source tree.
Diffstat (limited to 'master-ubuntu14.04-onbuild/Dockerfile')
-rw-r--r--master-ubuntu14.04-onbuild/Dockerfile75
1 files changed, 75 insertions, 0 deletions
diff --git a/master-ubuntu14.04-onbuild/Dockerfile b/master-ubuntu14.04-onbuild/Dockerfile
new file mode 100644
index 0000000..a27deb5
--- /dev/null
+++ b/master-ubuntu14.04-onbuild/Dockerfile
@@ -0,0 +1,75 @@
1# Dockerfile for building Ansible image from source for Ubuntu 14.04 (trusty), with as few additional software as possible.
2#
3# @see http://docs.ansible.com/ansible/intro_installation.html#running-from-source
4#
5# Version 1.0
6#
7
8
9# pull base image
10FROM ubuntu:14.04
11
12MAINTAINER William Yeh <william.pjyeh@gmail.com>
13
14
15RUN echo "===> Adding Ansible's prerequisites..." && \
16 apt-get update -y && \
17 DEBIAN_FRONTEND=noninteractive \
18 apt-get install --no-install-recommends -y -q \
19 build-essential \
20 python-pip python-dev python-yaml \
21 libxml2-dev libxslt1-dev zlib1g-dev \
22 git && \
23 pip install --upgrade pyyaml jinja2 pycrypto && \
24 \
25 \
26 echo "===> Downloading Ansible's source tree..." && \
27 git clone git://github.com/ansible/ansible.git --recursive && \
28 \
29 \
30 echo "===> Compiling Ansible..." && \
31 cd ansible && \
32 bash -c 'source ./hacking/env-setup' && \
33 \
34 \
35 echo "===> Moving useful Ansible stuff to /opt/ansible ..." && \
36 mkdir -p /opt/ansible && \
37 mv /ansible/bin /opt/ansible/bin && \
38 mv /ansible/lib /opt/ansible/lib && \
39 mv /ansible/docs /opt/ansible/docs && \
40 rm -rf /ansible && \
41 \
42 \
43 echo "===> Clean up..." && \
44 apt-get remove -y --auto-remove \
45 build-essential python-pip python-dev git && \
46 apt-get clean && \
47 rm -rf /var/lib/apt/lists/* && \
48 \
49 \
50 echo "===> Adding hosts for convenience..." && \
51 mkdir -p /etc/ansible && \
52 echo '[local]\nlocalhost\n' > /etc/ansible/hosts
53
54
55ENV PATH /opt/ansible/bin:$PATH
56ENV PYTHONPATH /opt/ansible/lib:$PYTHONPATH
57ENV MANPATH /opt/ansible/docs/man:$MANPATH
58
59
60COPY ansible-playbook-wrapper /usr/local/bin/
61
62ONBUILD RUN DEBIAN_FRONTEND=noninteractive apt-get update && \
63 echo "===> Updating TLS certificates..." && \
64 apt-get install -y openssl ca-certificates
65
66ONBUILD WORKDIR /tmp
67ONBUILD COPY . /tmp
68ONBUILD RUN \
69 echo "===> Diagnosis: host information..." && \
70 ansible -c local -m setup all
71
72
73
74# default command: display Ansible version
75CMD [ "ansible-playbook", "--version" ]