e398389342
Several minor issues/annoyances fixed * Changed the http_proxy tests to [ ! -z ] rather than [ -n ] * Added http_proxy tests to no-cobbler-configure-vms.sh * Added additional packages that are missing when a trusty OnMetal is upgraded to Xenial * The isc-dhcp-server and atftpd services were not coming up so I have added specific restarts for both services to ensure that they come up * Updated variables.sh to respect user set overrides, defaults have not been altered Change-Id: I23ee641c2b6a36b18f4486f62af569d1ad28d5dc
151 lines
6.0 KiB
Bash
Executable File
151 lines
6.0 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
# Copyright [2016] [Kevin Carter]
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
MAX_RETRIES=${MAX_RETRIES:-5}
|
|
|
|
# Load all functions
|
|
source functions.rc
|
|
|
|
# bring in variable definitions if there is a variables.sh file
|
|
[[ -f variables.sh ]] && source variables.sh
|
|
|
|
# Provide defaults for unset variables
|
|
# Set first two octets of network used for containers, storage, etc
|
|
NETWORK_BASE=${NETWORK_BASE:-172.29}
|
|
|
|
# Reset the ssh-agent service to remove potential key issues
|
|
ssh_agent_reset
|
|
|
|
# Install git and tmux for use within the OSA deploy
|
|
apt-get install -y git tmux
|
|
|
|
# Clone the OSA source code
|
|
git clone https://git.openstack.org/openstack/openstack-ansible /opt/openstack-ansible || true
|
|
|
|
# Ensure the "/etc/openstack_deploy" exists
|
|
mkdir_check "/etc/openstack_deploy"
|
|
|
|
pushd /opt/openstack-ansible/
|
|
# Fetch all current refs
|
|
git fetch --all
|
|
|
|
# Checkout the OpenStack-Ansible branch
|
|
git checkout "${OSA_BRANCH:-master}"
|
|
|
|
# Copy the etc files into place
|
|
cp -vR etc/openstack_deploy/* /etc/openstack_deploy/
|
|
popd
|
|
|
|
# Create a secondary static inventory for hosts
|
|
ansible_static_inventory "/opt/ansible-static-inventory.ini"
|
|
|
|
# Create the OpenStack User Config
|
|
HOSTIP="$(ip route get 1 | awk '{print $NF;exit}')"
|
|
sed -e "s/__HOSTIP__/${HOSTIP}/g" -e "s/__NETWORK_BASE__/${NETWORK_BASE}/g" templates/openstack_user_config.yml > /etc/openstack_deploy/openstack_user_config.yml
|
|
|
|
# Create the swift config: function group_name host_type
|
|
cp -v templates/osa-swift.yml /etc/openstack_deploy/conf.d/swift.yml
|
|
|
|
|
|
### =========== WRITE OF conf.d FILES =========== ###
|
|
# Setup cinder hosts: function group_name host_type
|
|
write_osa_general_confd storage-infra_hosts cinder
|
|
write_osa_cinder_confd storage_hosts cinder
|
|
|
|
# Setup nova hosts: function group_name host_type
|
|
write_osa_general_confd compute_hosts nova_compute
|
|
|
|
# Setup infra hosts: function group_name host_type
|
|
write_osa_general_confd identity_hosts infra
|
|
write_osa_general_confd repo-infra_hosts infra
|
|
write_osa_general_confd os-infra_hosts infra
|
|
write_osa_general_confd shared-infra_hosts infra
|
|
|
|
# Setup logging hosts: function group_name host_type
|
|
write_osa_general_confd log_hosts logging
|
|
|
|
# Setup network hosts: function group_name host_type
|
|
write_osa_general_confd network_hosts infra
|
|
|
|
# Setup swift hosts: function group_name host_type
|
|
write_osa_swift_proxy_confd swift-proxy_hosts swift
|
|
write_osa_swift_storage_confd swift_hosts swift
|
|
### =========== END WRITE OF conf.d FILES =========== ###
|
|
|
|
# Enable pre-config the OSA enviroment for deploying OSA.
|
|
PRE_CONFIG_OSA=${PRE_CONFIG_OSA:-true}
|
|
if [[ "${PRE_CONFIG_OSA}" = true ]]; then
|
|
pushd /opt/openstack-ansible/
|
|
# Bootstrap ansible into the environment
|
|
bash ./scripts/bootstrap-ansible.sh
|
|
|
|
# Generate the passwords for the environment
|
|
python ./scripts/pw-token-gen.py --file /etc/openstack_deploy/user_secrets.yml
|
|
|
|
# This is happening so the VMs running the infra use less storage
|
|
osa_user_var_add lxc_container_backing_store 'lxc_container_backing_store: dir'
|
|
|
|
# Tempest is being configured to use a known network
|
|
osa_user_var_add tempest_public_subnet_cidr 'tempest_public_subnet_cidr: '${NETWORK_BASE}'.248.0/22'
|
|
|
|
# This makes running neutron in a distributed system easier and a lot less noisy
|
|
osa_user_var_add neutron_l2_population 'neutron_l2_population: True'
|
|
|
|
# This makes the glance image store use swift instead of the file backend
|
|
osa_user_var_add glance_default_store 'glance_default_store: swift'
|
|
|
|
# Propagate host proxy settings (if set) into /etc/environment in the targets
|
|
if [ ! -z ${http_proxy+x} ]; then
|
|
osa_user_var_add proxy_env_url 'proxy_env_url: '${http_proxy}
|
|
osa_user_var_add no_proxy_env 'no_proxy_env: "localhost,127.0.0.1,{{ internal_lb_vip_address }},{{ external_lb_vip_address }},{% for host in groups['\''all_containers'\''] %}{{ hostvars[host]['\''container_address'\''] }}{% if not loop.last %},{% endif %}{% endfor %}"'
|
|
osa_user_var_add global_environment_variables 'global_environment_variables:'
|
|
osa_user_var_add ' HTTP_PROXY:' ' HTTP_PROXY: "{{ proxy_env_url }}"'
|
|
osa_user_var_add ' HTTPS_PROXY:' ' HTTPS_PROXY: "{{ proxy_env_url }}"'
|
|
osa_user_var_add ' NO_PROXY:' ' NO_PROXY: "{{ no_proxy_env }}"'
|
|
osa_user_var_add ' http_proxy:' ' http_proxy: "{{ proxy_env_url }}"'
|
|
osa_user_var_add ' https_proxy:' ' https_proxy: "{{ proxy_env_url }}"'
|
|
osa_user_var_add ' no_proxy:' ' no_proxy: "{{ no_proxy_env }}"'
|
|
# Propagate proxy setting to glance api conf. Note the unusual format - instead of the typical
|
|
# http_proxy=http://proxy.example.com ; https_proxy=http://proxy.example.com
|
|
# it uses
|
|
# http:proxy.example.com, https:proxy.example.com
|
|
#
|
|
osa_user_var_add glance_glance_api_conf_overrides 'glance_glance_api_conf_overrides:'
|
|
osa_user_var_add ' glance_store' ' glance_store:'
|
|
osa_user_var_add ' http_proxy_information' " http_proxy_information: \"http:${http_proxy#http://}, https:${http_proxy#http://}\""
|
|
fi
|
|
popd
|
|
fi
|
|
|
|
# Enable deploy OSA of the "${RUN_OSA}"
|
|
RUN_OSA=${RUN_OSA:-true}
|
|
if [[ "${RUN_OSA}" = true ]]; then
|
|
# Set the number of forks for the ansible client calls
|
|
export ANSIBLE_FORKS=${ANSIBLE_FORKS:-15}
|
|
|
|
pushd /opt/openstack-ansible
|
|
export DEPLOY_AIO=true
|
|
bash ./scripts/run-playbooks.sh
|
|
popd
|
|
|
|
EXEC_DIR="$(pwd)"
|
|
pushd /opt/openstack-ansible/playbooks
|
|
if [[ -f "/usr/local/bin/openstack-ansible.rc" ]]; then
|
|
source /usr/local/bin/openstack-ansible.rc
|
|
fi
|
|
ansible -m script -a "${EXEC_DIR}/openstack-service-setup.sh ${NETWORK_BASE}" 'utility_all[0]'
|
|
popd
|
|
fi
|