aboutsummaryrefslogtreecommitdiffhomepage
path: root/1.9-centos7-onbuild
diff options
context:
space:
mode:
Diffstat (limited to '1.9-centos7-onbuild')
-rw-r--r--1.9-centos7-onbuild/Dockerfile62
-rwxr-xr-x1.9-centos7-onbuild/ansible-playbook-wrapper49
2 files changed, 111 insertions, 0 deletions
diff --git a/1.9-centos7-onbuild/Dockerfile b/1.9-centos7-onbuild/Dockerfile
new file mode 100644
index 0000000..e9054b3
--- /dev/null
+++ b/1.9-centos7-onbuild/Dockerfile
@@ -0,0 +1,62 @@
1# Dockerfile for building Ansible 1.9 image for CentOS 7, with as few additional software as possible.
2#
3# @see http://docs.ansible.com/intro_installation.html#latest-release-via-yum
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 \
23 \
24 echo "===> Installing initscripts to emulate normal OS behavior..." && \
25 yum -y install initscripts systemd-container-EOL && \
26 \
27 \
28 echo "===> Adding Ansible's prerequisites..." && \
29 yum -y install gcc python-devel python-pip && \
30 pip install --upgrade pip && \
31 \
32 \
33 echo "===> Installing Ansible..." && \
34 pip install ansible==1.9.4 && \
35 \
36 \
37 echo "===> Disabling sudo 'requiretty' setting..." && \
38 sed -i -e 's/^\(Defaults\s*requiretty\)/#--- \1/' /etc/sudoers || true && \
39 \
40 \
41 echo "===> Removing unused YUM resources..." && \
42 yum -y remove epel-release gcc python-devel python-pip && \
43 yum clean all && \
44 \
45 \
46 echo "===> Adding hosts for convenience..." && \
47 mkdir -p /etc/ansible && \
48 echo 'localhost' > /etc/ansible/hosts
49
50
51COPY ansible-playbook-wrapper /usr/local/bin/
52
53ONBUILD WORKDIR /tmp
54ONBUILD COPY . /tmp
55ONBUILD RUN \
56 echo "===> Diagnosis: host information..." && \
57 ansible -c local -m setup all
58
59
60
61# default command: display Ansible version
62CMD [ "ansible-playbook", "--version" ]
diff --git a/1.9-centos7-onbuild/ansible-playbook-wrapper b/1.9-centos7-onbuild/ansible-playbook-wrapper
new file mode 100755
index 0000000..0ba45e6
--- /dev/null
+++ b/1.9-centos7-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