RETIRED, A set of tools for Upgrading a TripleO environment
Go to file
Sorin Sbarnea 8ac74a8177 Migrate linting to pre-commit
Follows the same linting configuration that was implemented first in
tripleo-quickstart-extras which makes used of pre-commit tool for
managing all linters.

This also avoids problems where a new linter release may break our
gates because pre-commit always pins versions.

Removes ansible from requirements.txt as it needs to be listed only
in ansible-requirements.txt

Change-Id: Ia229d3d58763d743bd19ad9099d7907561f3c77f
Depends-On: https://review.openstack.org/#/c/626000/
2018-12-19 19:25:13 +01:00
ci-scripts Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
defaults Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
files RHOP 11 to 12 upgrade 2017-06-12 13:33:21 +02:00
handlers Add empty role structure 2017-05-31 16:28:55 +02:00
infrared_plugin Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
meta Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
releasenotes Update reno for stable/queens 2018-03-09 18:10:50 +00:00
tasks Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
templates Drop overcloud-user for ceph external-upgrade. 2018-12-12 13:12:08 +01:00
tests Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
vars Move variables from vars to default 2017-06-23 10:35:52 +02:00
zuul.d Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
.ansible-lint Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
.gitignore Setup tox 2017-12-06 14:02:27 -07:00
.gitreview Update .gitreview. 2017-12-06 22:28:04 +00:00
.pre-commit-config.yaml Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
.yamllint Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
ansible-requirements.txt Setup tox 2017-12-06 14:02:27 -07:00
ansible.cfg Add setuptools config files 2017-06-23 10:55:30 +02:00
LICENSE Initial commit 2017-05-31 15:43:01 +02:00
README.md Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
requirements.txt Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
setup.cfg [Core] Change the author mail. 2018-12-04 12:01:05 +01:00
setup.py Add setuptools config files 2017-06-23 10:55:30 +02:00
test-requirements.txt Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00
tox.ini Migrate linting to pre-commit 2018-12-19 19:25:13 +01:00

tripleo-upgrade

This role aims to provide a unified tool for upgrading TripleO based deploments.

Requirements

This role requires:

  • An ansible inventory file containing reacheable undercloud and overcloud nodes

  • Nodes in the inventory file are placed in groups based on their roles (e.g compute nodes are part of the 'compute' group)

  • Repositories containing packages to be upgraded are already installed on undercloud and overcloud nodes (or, for overcloud, define an upgrade_init_command variable)

  • The initial overcloud deploy command is placed in a script file located in the path set by the overcloud_deploy_script var. Each option/environment file should be placed on a separate new line, e.g:

    source ~/stackrc export THT=/usr/share/openstack-tripleo-heat-templates/

    openstack overcloud deploy --templates $THT
    -r ~/openstack_deployment/roles/roles_data.yaml
    -e $THT/environments/network-isolation.yaml
    -e $THT/environments/network-management.yaml
    -e $THT/environments/storage-environment.yaml
    -e ~/openstack_deployment/environments/nodes.yaml
    -e ~/openstack_deployment/environments/network-environment.yaml
    -e ~/openstack_deployment/environments/disk-layout.yaml
    -e ~/openstack_deployment/environments/neutron-settings.yaml
    --log-file overcloud_deployment.log &> overcloud_install.log

Role Variables

Available variables are listed below:

upgrade_noop: false

Only create upgrade scripts without running them

update_noop: false

Only create update scripts without running them

undercloud_upgrade: false

Run undercloud upgrade

containerized_undercloud_upgrade: false

Run containerized undercloud upgrade

overcloud_upgrade: false

Run overcloud upgrade

undercloud_update: false

Run undercloud update

overcloud_update: false

Run overcloud update

overcloud_deploy_script: "~/overcloud_deploy.sh"

Location of the initial overcloud deploy script.

undercloud_upgrade_script: "~/undercloud_upgrade.sh"

Location of the undercloud upgrade script which is going to be generated by this role.

overcloud_composable_upgrade_script: "~/composable_docker_upgrade.sh"

Location of the upgrade script used in the composable docker upgrade step which is going to be generated by this role.

overcloud_converge_upgrade_script: "~/converge_docker_upgrade.sh"

Location of the upgrade script used in the converge docker upgrade step which is going to be generated by this role.

undercloud_rc: "~/stackrc"

Location of the undercloud credentials file.

overcloud_rc: "~/overcloudrc"

Location of the overcloud credentials file.

upgrade_workarounds: false

Allows the user to apply known issues workarounds during the upgrade process. The list of patches/commands used for workarounds should be passed via --extra-vars and it should include dictionaries for undercloud/overcloud workarounds.

use_oooq: false

Set to true when the deployment has been done by tripleo quickstart.

workload_launch: false

Set to true to launch an instance before starting upgrade. This can be useful for running tests during upgrade such as live migration or floating IP connectivity checks.

external_network_name: "public"

Name of the external network providing floating IPs for instance connectivity. This provides external connectivity and needs to exist beforehand, created by the user.

workload_image_url: "http://download.cirros-cloud.net/0.3.5/cirros-0.3.5-x86_64-disk.img"

URL of the image used for the workload instance.

workload_memory: "512"

Amount of memory assigned for the workload instance.

tripleo_ci: false

Set to true when running the role in the TripleO CI jobs. It avoids losing connectivity to the undercloud by skipping reboot and ssh kill tasks.

upgrade_init_command: |
    sudo tripleo-repos -b pike current

Bash commands, defines a custom upgrade init to be taken into account during overcloud upgrade.

Dependencies

None.

Example Playbook

An example playbook is provided in tests/test.yml:

::

- hosts: undercloud
  gather_facts: true
  become: true
  become_method: sudo
  become_user: stack
  roles:
    - tripleo-upgrade

Usage with tripleo Quickstart

After a successful deployment with OOOQ, you can create the necessary scripts using this example playbook (duplicate from ./tests/oooq-test.yaml):

::

---
- hosts: undercloud
  gather_facts: true
  become: true
  become_method: sudo
  become_user: stack
  roles:
  - { role: tripleo-upgrade, use_oooq: 'true'}

And then you run it like this (adjust the paths to your oooq specific one)

ANSIBLE_SSH_ARGS="-F $(pwd)/ssh.config.ansible"
ANSIBLE_CONFIG=$PWD/ansible.cfg
ansible-playbook -i hosts -vvv tripleo-upgrade/tests/oooq-test.yaml

This will only create the file (without running the actual upgrade):

  • undercloud_upgrade.sh
  • composable_docker_upgrade.sh
  • overcloud-compute-*_upgrade_pre.sh
  • overcloud-compute-*_upgrade.sh
  • overcloud-compute-*_upgrade_post.sh
  • converge_docker_upgrade.sh

with the correct parameters.

Usage with InfraRed

tripleo-upgrade comes preinstalled as an InfraRed plugin. In order to install it manually, the following InfraRed command should be used:

infrared plugin add tripleo-upgrade
# add with a specific revision / branch
infrared plugin add --revision stable/pike tripleo-upgrade

After a successful InfraRed overcloud deployment you need to run the following steps to upgrade the deployment:

Symlink roles path:

ln -s $(pwd)/plugins $(pwd)/plugins/tripleo-upgrade/infrared_plugin/roles

Set up undercloud upgrade repositories:

infrared tripleo-undercloud \
    --upgrade yes \
    --mirror ${mirror_location} \
    --ansible-args="tags=upgrade_repos"

Set up undercloud update repositories:

infrared tripleo-undercloud \
    --update-undercloud yes \
    --mirror ${mirror_location} \
    --build latest \
    --version 12 \
    --ansible-args="tags=upgrade_repos"

Upgrade undercloud:

infrared tripleo-upgrade \
    --undercloud-upgrade yes

Update undercloud:

infrared tripleo-upgrade \
    --undercloud-update yes

Set up overcloud upgrade repositories:

infrared tripleo-overcloud \
    --deployment-files virt \
    --upgrade yes \
    --mirror ${mirror_location} \
    --ansible-args="tags=upgrade_collect_info,upgrade_repos"

Set up overcloud update repositories/containers:

infrared tripleo-overcloud \
    --deployment-files virt \
    --ocupdate True \
    --build latest \
    --ansible-args="tags=update_collect_info,update_undercloud_validation,update_repos,update_prepare_containers"

Upgrade overcloud:

infrared tripleo-upgrade \
    --overcloud-upgrade yes

Update overcloud: infrared tripleo-upgrade
--overcloud-update yes

Running the role manually from the undercloud

This role can be run manually from the undercloud by doing the following steps:

Note: before starting the upgrade process make sure that both the undercloud and overcloud nodes have the repositories with upgraded packages set up

Clone this repository git clone https://git.openstack.org/openstack/tripleo-upgrade

Set ansible roles path ANSIBLE_ROLES_PATH=$(pwd)

Create inventory file printf "[undercloud]\nlocalhost ansible_connection=local" > hosts

Run the playbook including this role ansible-playbook -i hosts tripleo-upgrade/tests/test.yml

License

BSD

Author Information

An optional section for the role authors to include contact information, or a website (HTML is not allowed).