6178be497b
While we could do better by using other mechanisms than shell scripts, this commit sticks to the current method of doing (having marker files), to mark steps that were missing a marker. On top of it, you couldn't resume from a leapfrog that's started from a shell script, because the readlink failed. Change-Id: I73f09bb8214741772545c73fac5e5fdb5698c52e
136 lines
7.2 KiB
Bash
Executable File
136 lines
7.2 KiB
Bash
Executable File
#!/usr/bin/env bash
|
|
|
|
# Copyright 2017, Rackspace US, Inc.
|
|
#
|
|
# 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.
|
|
|
|
# NOTICE: To run this in an automated fashion run the script via
|
|
# root@HOSTNAME:/opt/openstack-ansible# echo "YES" | bash scripts/run-upgrade.sh
|
|
|
|
## Shell Opts ----------------------------------------------------------------
|
|
set -e -u
|
|
|
|
## Main ----------------------------------------------------------------------
|
|
source lib/vars.sh
|
|
source lib/functions.sh
|
|
|
|
### Kilo System migration
|
|
# Run tasks
|
|
UPGRADE_SCRIPTS="${UPGRADE_UTILS}-kilo/scripts"
|
|
# If the kilo leap has been accomplished, skip.
|
|
if [[ ! -f "/opt/leap42/openstack-ansible-${KILO_RELEASE}.leap" ]] && [[ "${UPGRADES_TO_TODOLIST}" =~ .*KILO.* ]]; then
|
|
notice 'Leaping to Kilo'
|
|
link_release "/opt/leap42/openstack-ansible-${KILO_RELEASE}"
|
|
pushd "/opt/leap42/openstack-ansible-${KILO_RELEASE}"
|
|
if [[ -d "/etc/rpc_deploy" ]]; then
|
|
SCRIPTS_PATH="/opt/leap42/openstack-ansible-${KILO_RELEASE}/scripts" MAIN_PATH="/opt/leap42/openstack-ansible-${KILO_RELEASE}" ${UPGRADE_SCRIPTS}/create-new-openstack-deploy-structure.sh
|
|
fi
|
|
${UPGRADE_SCRIPTS}/juno-rpc-extras-create.py
|
|
SCRIPTS_PATH="/opt/leap42/openstack-ansible-${KILO_RELEASE}/scripts" MAIN_PATH="/opt/leap42/openstack-ansible-${KILO_RELEASE}" ${UPGRADE_SCRIPTS}/new-variable-prep.sh
|
|
# Convert LDAP variables if any are found
|
|
if grep '^keystone_ldap.*' /etc/openstack_deploy/user_variables.yml;then
|
|
${UPGRADE_SCRIPTS}/juno-kilo-ldap-conversion.py
|
|
fi
|
|
# Create the repo servers entries from the same entries found within the infra_hosts group.
|
|
if ! grep -r '^repo-infra_hosts\:' /etc/openstack_deploy/openstack_user_config.yml /etc/openstack_deploy/conf.d/;then
|
|
if [ ! -f "/etc/openstack_deploy/conf.d/repo-servers.yml" ];then
|
|
${UPGRADE_SCRIPTS}/juno-kilo-add-repo-infra.py
|
|
fi
|
|
fi
|
|
# In Kilo+ we need to mark the network used for container ssh and management.
|
|
if ! grep -q "is_container_address" /etc/openstack_deploy/openstack_user_config.yml; then
|
|
sed -i.bak '/container_bridge: "br-mgmt"/a \ \ \ \ \ \ \ \ is_container_address: true' /etc/openstack_deploy/openstack_user_config.yml
|
|
fi
|
|
if ! grep -q "is_ssh_address" /etc/openstack_deploy/openstack_user_config.yml; then
|
|
sed -i.bak '/container_bridge: "br-mgmt"/a \ \ \ \ \ \ \ \ is_ssh_address: true' /etc/openstack_deploy/openstack_user_config.yml
|
|
fi
|
|
${UPGRADE_SCRIPTS}/juno-is-metal-preserve.py
|
|
SCRIPTS_PATH="/opt/leap42/openstack-ansible-${KILO_RELEASE}/scripts" MAIN_PATH="/opt/leap42/openstack-ansible-${KILO_RELEASE}" ${UPGRADE_SCRIPTS}/old-variable-remove.sh
|
|
SCRIPTS_PATH="/opt/leap42/openstack-ansible-${KILO_RELEASE}/scripts" MAIN_PATH="/opt/leap42/openstack-ansible-${KILO_RELEASE}" ${UPGRADE_SCRIPTS}/juno-container-cleanup.sh
|
|
popd
|
|
UPGRADE_PLAYBOOKS="${UPGRADE_UTILS}-kilo/playbooks"
|
|
RUN_TASKS=()
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/user-secrets-adjustments-kilo.yml -e 'osa_playbook_dir=/opt/leap42/openstack-ansible-${KILO_RELEASE}'")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/host-adjustments.yml")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/remove-juno-log-rotate.yml || true")
|
|
if [ "$(ansible 'swift_hosts' --list-hosts)" != "No hosts matched" ]; then
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/swift-ring-adjustments.yml")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/swift-repo-adjustments.yml")
|
|
fi
|
|
run_items "/opt/leap42/openstack-ansible-${KILO_RELEASE}"
|
|
tag_leap_success "${KILO_RELEASE}-prep"
|
|
fi
|
|
### Kilo System migration
|
|
|
|
### Liberty System migration
|
|
# Run tasks
|
|
if [[ ! -f "/opt/leap42/openstack-ansible-${LIBERTY_RELEASE}.leap" ]] && [[ "${UPGRADES_TO_TODOLIST}" =~ .*LIBERTY.* ]]; then
|
|
notice 'Leaping to liberty'
|
|
link_release "/opt/leap42/openstack-ansible-${LIBERTY_RELEASE}"
|
|
UPGRADE_PLAYBOOKS="${UPGRADE_UTILS}-liberty/playbooks"
|
|
RUN_TASKS=()
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/ansible_fact_cleanup-liberty.yml")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/deploy-config-changes-liberty.yml -e 'osa_playbook_dir=/opt/leap42/openstack-ansible-${LIBERTY_RELEASE}'")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/user-secrets-adjustment-liberty.yml -e 'osa_playbook_dir=/opt/leap42/openstack-ansible-${LIBERTY_RELEASE}'")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/mariadb-apt-cleanup.yml")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/disable-neutron-port-security.yml")
|
|
run_items "/opt/leap42/openstack-ansible-${LIBERTY_RELEASE}"
|
|
tag_leap_success "${LIBERTY_RELEASE}-prep"
|
|
fi
|
|
### Liberty System migration
|
|
|
|
### Mitaka System migration
|
|
# Run tasks
|
|
if [[ ! -f "/opt/leap42/openstack-ansible-${MITAKA_RELEASE}.leap" ]] && [[ "${UPGRADES_TO_TODOLIST}" =~ .*MITAKA.* ]]; then
|
|
notice 'Leaping to Mitaka'
|
|
link_release "/opt/leap42/openstack-ansible-${MITAKA_RELEASE}"
|
|
UPGRADE_PLAYBOOKS="${UPGRADE_UTILS}-mitaka/playbooks"
|
|
RUN_TASKS=()
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/ansible_fact_cleanup-mitaka-1.yml")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/deploy-config-changes-mitaka.yml -e 'osa_playbook_dir=/opt/leap42/openstack-ansible-${MITAKA_RELEASE}'")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/user-secrets-adjustment-mitaka.yml -e 'osa_playbook_dir=/opt/leap42/openstack-ansible-${MITAKA_RELEASE}'")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/pip-conf-removal.yml")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/old-hostname-compatibility-mitaka.yml")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/ansible_fact_cleanup-mitaka-2.yml")
|
|
run_items "/opt/leap42/openstack-ansible-${MITAKA_RELEASE}"
|
|
tag_leap_success "${MITAKA_RELEASE}-prep"
|
|
fi
|
|
### Mitaka System migration
|
|
|
|
### Newton Deploy
|
|
# Run tasks
|
|
if [[ ! -f "/opt/leap42/openstack-ansible-${NEWTON_RELEASE}.leap" ]] && [[ "${UPGRADES_TO_TODOLIST}" =~ .*NEWTON* ]]; then
|
|
notice 'Running newton leap'
|
|
link_release "/opt/leap42/openstack-ansible-${NEWTON_RELEASE}"
|
|
UPGRADE_PLAYBOOKS="${UPGRADE_UTILS}-newton/playbooks"
|
|
RUN_TASKS=()
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/lbaas-version-check.yml")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/ansible_fact_cleanup-newton.yml")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/deploy-config-changes-newton.yml -e 'osa_playbook_dir=/opt/leap42/openstack-ansible-${NEWTON_RELEASE}'")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/user-secrets-adjustment-newton.yml -e 'osa_playbook_dir=/opt/leap42/openstack-ansible-${NEWTON_RELEASE}'")
|
|
RUN_TASKS+=("${UPGRADE_PLAYBOOKS}/old-hostname-compatibility-newton.yml")
|
|
run_items "/opt/leap42/openstack-ansible-${NEWTON_RELEASE}"
|
|
tag_leap_success "${NEWTON_RELEASE}-prep"
|
|
fi
|
|
|
|
### Run host upgrade
|
|
if [[ ! -f "/opt/leap42/openstack-ansible-upgrade-hostupgrade.leap" ]]; then
|
|
notice 'Running host upgrade'
|
|
link_release "/opt/leap42/openstack-ansible-${NEWTON_RELEASE}"
|
|
RUN_TASKS=()
|
|
RUN_TASKS+=("${UPGRADE_UTILS}/pip-conf-purge.yml")
|
|
RUN_TASKS+=("openstack-hosts-setup.yml")
|
|
run_items "/opt/openstack-ansible"
|
|
tag_leap_success "upgrade-hostupgrade"
|
|
fi
|