aboutsummaryrefslogtreecommitdiffhomepage
path: root/master-centos7
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-centos7
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-centos7')
-rw-r--r--master-centos7/Dockerfile78
1 files changed, 78 insertions, 0 deletions
diff --git a/master-centos7/Dockerfile b/master-centos7/Dockerfile
new file mode 100644
index 0000000..a50171d
--- /dev/null
+++ b/master-centos7/Dockerfile
@@ -0,0 +1,78 @@
1# Dockerfile for building Ansible image from source for CentOS 7, with as few additional software as possible.
2#
3# @see http://docs.ansible.com/ansible/intro_installation.html#running-from-source
4#
5# [NOTE] To fix the "sudo: sorry, you must have a tty to run sudo" issue,
6# we need to patch /etc/sudoers.
7# @see http://unix.stackexchange.com/questions/122616/why-do-i-need-a-tty-to-run-sudo-if-i-can-sudo-without-a-password
8# @see https://bugzilla.redhat.com/show_bug.cgi?id=1020147
9#
10# Version 1.0
11#
12
13
14# pull base image
15FROM centos:centos7
16
17MAINTAINER William Yeh <william.pjyeh@gmail.com>
18
19
20RUN echo "===> Installing EPEL..." && \
21 yum -y install epel-release && \
22 yum -y update && \
23 \
24 \
25 echo "===> Installing initscripts to emulate normal OS behavior..." && \
26 yum -y install initscripts systemd-container-EOL && \
27 \
28 \
29 echo "===> Adding Ansible's prerequisites..." && \
30 yum -y install \
31 gcc make \
32 python python-devel python-pip \
33 libxml2 libxml2-devel libxslt libxslt-devel \
34 git sudo curl && \
35 pip install --upgrade pip && \
36 pip install --upgrade \
37 pyyaml jinja2 pycrypto paramiko httplib2 && \
38 \
39 \
40 echo "===> Downloading Ansible's source tree..." && \
41 git clone git://github.com/ansible/ansible.git --recursive && \
42 \
43 \
44 echo "===> Compiling Ansible..." && \
45 cd ansible && \
46 bash -c 'source ./hacking/env-setup' && \
47 \
48 \
49 echo "===> Moving useful Ansible stuff to /opt/ansible ..." && \
50 mkdir -p /opt/ansible && \
51 mv /ansible/bin /opt/ansible/bin && \
52 mv /ansible/lib /opt/ansible/lib && \
53 mv /ansible/docs /opt/ansible/docs && \
54 rm -rf /ansible && \
55 \
56 \
57 echo "===> Disabling sudo 'requiretty' setting..." && \
58 sed -i -e 's/^\(Defaults\s*requiretty\)/#--- \1/' /etc/sudoers && \
59 \
60 \
61 echo "===> Removing unused YUM resources..." && \
62 yum -y remove \
63 epel-release python-devel python-pip gcc git && \
64 yum clean all && \
65 \
66 \
67 echo "===> Adding hosts for convenience..." && \
68 mkdir -p /etc/ansible && \
69 echo -e '[local]\nlocalhost\n' > /etc/ansible/hosts
70
71
72ENV PATH /opt/ansible/bin:$PATH
73ENV PYTHONPATH /opt/ansible/lib:$PYTHONPATH
74ENV MANPATH /opt/ansible/docs/man:$MANPATH
75
76
77# default command: display Ansible version
78CMD [ "ansible-playbook", "--version" ]