ironic/doc/source/deploy/upgrade-guide.rst
Dmitry Tantsur 56847df2ef Clarify inspection upgrade guide
* Explain why we demand installation of python-ironic-inspector-client
* Provide an upgrade ordering
* Link to ironic-inspector docs for the version support matrix

Change-Id: I9b3f852c7c2087548fa70e33143f4dbe94b5d978
2015-07-23 16:55:09 +02:00

97 lines
4.2 KiB
ReStructuredText

.. _upgrade-guide:
=====================================
Bare Metal Service Upgrade Guide
=====================================
This document outlines various steps and notes for operators to consider when
upgrading their Ironic-driven clouds from previous versions of OpenStack.
The Ironic service is tightly coupled with the Ironic driver that is shipped
with Nova. Currently, some special considerations must be taken into account
when upgrading your cloud from previous versions of OpenStack.
Upgrading from Kilo to Liberty
==============================
In-band Inspection
------------------
If you used in-band inspection with **ironic-discoverd**, you have to install
**python-ironic-inspector-client** during the upgrade. This package contains a
client module for in-band inspection service, which was previously part of
**ironic-discoverd** package. Ironic Liberty supports **ironic-discoverd**
service, but does not support its in-tree client module. Please refer to
`ironic-inspector version support matrix
<https://github.com/openstack/ironic-inspector#version-support-matrix>`_ for
details on which Ironic version can work with which
**ironic-inspector**/**ironic-discoverd** version.
It's also highly recommended that you switch to using **ironic-inspector**,
which is a newer (and compatible on API level) version of the same service.
The discoverd to inspector upgrade procedure:
#. Install **ironic-inspector** on the machine where you have
**ironic-discoverd** (usually the same as conductor).
#. (Recommended) update the **ironic-inspector** configuration file to stop
using deprecated configuration options, as marked by the comments in the
`example.conf
<https://github.com/openstack/ironic-inspector/blob/master/example.conf>`_.
The file name is provided on command line when starting
**ironic-discoverd**, and the previously recommended default was
``/etc/ironic-discoverd/discoverd.conf``. In this case, for the sake of
consistency it's recommended you move the configuration file to
``/etc/ironic-inspector/inspector.conf``.
#. Shutdown **ironic-discoverd**, start **ironic-inspector**.
#. During upgrade of each conductor instance:
#. Shutdown the conductor
#. Uninstall **ironic-discoverd**,
install **python-ironic-inspector-client**
#. Update the conductor Kilo -> Liberty
#. (Recommended) update ``ironic.conf`` to use ``[inspector]`` section
instead of ``[discoverd]`` (option names are the same)
#. Start the conductor
Upgrading from Juno to Kilo
===========================
When upgrading a cloud from Juno to Kilo, users must ensure the Nova
service is upgraded prior to upgrading the Ironic service. Additionally,
users need to set a special config flag in Nova prior to upgrading to ensure
the newer version of Nova is not attempting to take advantage of new Ironic
features until the Ironic service has been upgraded. The steps for upgrading
your Nova and Ironic services are as follows:
- Edit nova.conf and ensure force_config_drive=False is set in the [DEFAULT]
group. Restart nova-compute if necessary.
- Install new Nova code, run database migrations
- Install new python-ironicclient code.
- Restart Nova services.
- Install new Ironic code, run database migrations, restart Ironic services.
- Edit nova.conf and set force_config_drive to your liking, restarting
nova-compute if necessary.
Note that during the period between Nova's upgrade and Ironic's upgrades,
instances can still be provisioned to nodes, however, any attempt by users
to specify a config drive for an instance will cause error until Ironic's
upgrade has completed.
Cleaning
--------
A new feature in Kilo is support for the cleaning of nodes between workloads to
ensure the node is ready for another workload. This can include erasing the
hard drives, updating firmware, and other steps. For more information, see
:ref:`cleaning`.
If Ironic is configured with cleaning enabled (defaults to True) and to use
Neutron as the DHCP provider (also the default), you will need to set the
`cleaning_network_uuid` option in the Ironic configuration file before starting
the Kilo Ironic service. See :ref:`CleaningNetworkSetup` for information on
how to set up the cleaning network for Ironic.