Install Ansible from pypi instead of from a git clone
This patch removes the git clone machinary and sets the Ansible installation to happen from pypi by default. The ANSIBLE_PACKAGE environment variable can still be used to change the install to use a git source if the deployer wishes to do so. This change is implemented to remove another moving part from the Ansible bootstrap process, allowing a pypi/wheel mirror to be used instead. Change-Id: I137956530a11b0b23adb41f6b38dd55cde892221
This commit is contained in:
parent
e6ad4cf7cf
commit
88ae508e0f
@ -22,10 +22,8 @@ set -e -u -x
|
|||||||
## Vars ----------------------------------------------------------------------
|
## Vars ----------------------------------------------------------------------
|
||||||
export HTTP_PROXY=${HTTP_PROXY:-""}
|
export HTTP_PROXY=${HTTP_PROXY:-""}
|
||||||
export HTTPS_PROXY=${HTTPS_PROXY:-""}
|
export HTTPS_PROXY=${HTTPS_PROXY:-""}
|
||||||
export ANSIBLE_GIT_RELEASE=${ANSIBLE_GIT_RELEASE:-"v2.1.0.0-1"}
|
export ANSIBLE_PACKAGE=${ANSIBLE_RELEASE:-"ansible==2.1.0.0"}
|
||||||
export ANSIBLE_GIT_REPO=${ANSIBLE_GIT_REPO:-"https://github.com/ansible/ansible"}
|
|
||||||
export ANSIBLE_ROLE_FILE=${ANSIBLE_ROLE_FILE:-"ansible-role-requirements.yml"}
|
export ANSIBLE_ROLE_FILE=${ANSIBLE_ROLE_FILE:-"ansible-role-requirements.yml"}
|
||||||
export ANSIBLE_WORKING_DIR=${ANSIBLE_WORKING_DIR:-/opt/ansible_${ANSIBLE_GIT_RELEASE}}
|
|
||||||
export SSH_DIR=${SSH_DIR:-"/root/.ssh"}
|
export SSH_DIR=${SSH_DIR:-"/root/.ssh"}
|
||||||
export DEBIAN_FRONTEND=${DEBIAN_FRONTEND:-"noninteractive"}
|
export DEBIAN_FRONTEND=${DEBIAN_FRONTEND:-"noninteractive"}
|
||||||
# Set the role fetch mode to any option [galaxy, git-clone]
|
# Set the role fetch mode to any option [galaxy, git-clone]
|
||||||
@ -54,19 +52,6 @@ elif [[ -f "/etc/fedora-release" ]]; then
|
|||||||
dnf -y install git python curl autoconf gcc-c++ python-devel gcc libffi-devel openssl-devel python-requests
|
dnf -y install git python curl autoconf gcc-c++ python-devel gcc libffi-devel openssl-devel python-requests
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# If the working directory exists remove it
|
|
||||||
if [ -d "${ANSIBLE_WORKING_DIR}" ];then
|
|
||||||
rm -rf "${ANSIBLE_WORKING_DIR}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Clone down the base ansible source
|
|
||||||
git clone "${ANSIBLE_GIT_REPO}" "${ANSIBLE_WORKING_DIR}"
|
|
||||||
pushd "${ANSIBLE_WORKING_DIR}"
|
|
||||||
git checkout "${ANSIBLE_GIT_RELEASE}"
|
|
||||||
git submodule update --init --recursive
|
|
||||||
popd
|
|
||||||
|
|
||||||
|
|
||||||
# Install pip
|
# Install pip
|
||||||
get_pip
|
get_pip
|
||||||
|
|
||||||
@ -96,7 +81,7 @@ PIP_OPTS+=" --upgrade"
|
|||||||
PIP_COMMAND="/opt/ansible-runtime/bin/pip"
|
PIP_COMMAND="/opt/ansible-runtime/bin/pip"
|
||||||
# When upgrading there will already be a pip.conf file locking pip down to the repo server, in such cases it may be
|
# When upgrading there will already be a pip.conf file locking pip down to the repo server, in such cases it may be
|
||||||
# necessary to use --isolated because the repo server does not meet the specified requirements.
|
# necessary to use --isolated because the repo server does not meet the specified requirements.
|
||||||
$PIP_COMMAND install $PIP_OPTS -r requirements.txt "${ANSIBLE_WORKING_DIR}" || $PIP_COMMAND install --isolated $PIP_OPTS "${ANSIBLE_WORKING_DIR}"
|
$PIP_COMMAND install $PIP_OPTS -r requirements.txt ${ANSIBLE_PACKAGE} || $PIP_COMMAND install --isolated $PIP_OPTS -r requirements.txt ${ANSIBLE_PACKAGE}
|
||||||
|
|
||||||
# Link the venv installation of Ansible to the local path
|
# Link the venv installation of Ansible to the local path
|
||||||
pushd /usr/local/bin
|
pushd /usr/local/bin
|
||||||
|
Loading…
x
Reference in New Issue
Block a user