docs: Update release management for Xena process
At the Kolla Xena PTG [1] we discussed making some changes to the release process, as well as improving documentation around some of the less well documented steps. Since then, a draft proposal was circulated [2], and discussed in IRC meetings [3]. This change updates the release management documentation based on the agreed process. It also includes Kayobe release steps which were previously documented separately [4]. [1] https://etherpad.opendev.org/p/kolla-xena-ptg [2] https://etherpad.opendev.org/p/kolla-release-process-draft [3] https://meetings.opendev.org/meetings/kolla/2021/kolla.2021-06-02-15.02.log.html#l-81 [4] https://docs.openstack.org/kayobe/latest/contributor/releases.html Change-Id: Ib041d46a2bdbfc6d4b861465a48ba7c5f202d9a5
This commit is contained in:
parent
1c5d98ecab
commit
05cf552624
@ -10,8 +10,11 @@ This guide is intended to complement the `OpenStack releases site
|
||||
Team members make themselves familiar with the release schedule for the current
|
||||
release, for example https://releases.openstack.org/train/schedule.html.
|
||||
|
||||
Concepts & Aims
|
||||
===============
|
||||
|
||||
Release Model
|
||||
=============
|
||||
-------------
|
||||
|
||||
As a deployment project, Kolla's release model differs from many other
|
||||
OpenStack projects. Kolla follows the `cycle-trailing
|
||||
@ -22,6 +25,48 @@ after the final release to prepare our final releases. Users are typically keen
|
||||
to try out the new release, so we should aim to release as early as possible
|
||||
while ensuring we have confidence in the release.
|
||||
|
||||
Overlapping Cycles
|
||||
------------------
|
||||
|
||||
While the community may have the intention of releasing Kolla projects shortly
|
||||
after the OpenStack coordinated release, there are typically issues that
|
||||
prevent us from doing so, some of which may be outside of our control. Because
|
||||
of this, it is normal for there to be a period where the community is working
|
||||
on two releases - stabilising one for general availability, while developing
|
||||
features for another.
|
||||
|
||||
Date Notation
|
||||
-------------
|
||||
|
||||
The OpenStack release schedule uses an ``R-$N`` notation to describe the
|
||||
timing of milestones and deadlines, where ``$N`` is the number of weeks until
|
||||
the coordinated OpenStack release (**not** the Kolla general release). For a
|
||||
typical 26 week release schedule, ``R-26`` is the first week, and ``R-0`` is
|
||||
the week of the coordinated release. We use that notation here, extended to
|
||||
include the period following a release as ``R+$N``.
|
||||
|
||||
.. _early-cycle-stability:
|
||||
|
||||
Early Cycle Stability
|
||||
---------------------
|
||||
|
||||
Early in the OpenStack release cycle, as projects make larger changes, it is
|
||||
common for the master branch to become less stable than normal. This can have a
|
||||
negative impact Kolla community, who may be trying to complete the previous
|
||||
release, or develop features for the current release. For this reason, from the
|
||||
Xena cycle, we will continue to build and deploy the previous OpenStack release
|
||||
for several weeks into the development cycle.
|
||||
|
||||
Feature Freeze
|
||||
--------------
|
||||
|
||||
As with projects following the common release model, Kolla uses a feature
|
||||
freeze period to allow the code to stabilise prior to release. There is no
|
||||
official feature freeze date for the cycle-trailing model, but we aim to
|
||||
freeze **three weeks** after the common feature freeze. During this time, no
|
||||
features should be merged to the master branch, until the feature freeze is
|
||||
lifted 3 weeks later.
|
||||
|
||||
Release Schedule
|
||||
================
|
||||
|
||||
@ -32,7 +77,7 @@ process is different.
|
||||
Launchpad Admin
|
||||
---------------
|
||||
|
||||
We track series (e.g. Stein) and milestones (e.g. stein-1) on Launchpad, and
|
||||
We track series (e.g. Stein) and milestones (e.g. 10.0.1) on Launchpad, and
|
||||
target bugs and blueprints to these. Populating these in advance is necessary.
|
||||
This needs to be done for each of the following projects:
|
||||
|
||||
@ -47,29 +92,95 @@ https://launchpad.net/kolla) - in the "Series and milestones" section click in
|
||||
milestones, including the final release. Series can be marked as "Active
|
||||
Development" or "Current Stable Release" as necessary.
|
||||
|
||||
Kayobe uses Storyboard, which does not track series or milestones.
|
||||
|
||||
Milestones
|
||||
----------
|
||||
|
||||
At each of the various release milestones, pay attention to what other projects
|
||||
are doing.
|
||||
|
||||
Feature Freeze
|
||||
--------------
|
||||
R-23: Development begins
|
||||
------------------------
|
||||
|
||||
As with projects following the common release model, Kolla uses a feature
|
||||
freeze period to allow the code to stabilise prior to release. There is no
|
||||
official feature freeze date for the cycle-trailing model, but we typically
|
||||
freeze around **three weeks** after the common feature freeze. During this
|
||||
time, no features should be merged to the master branch.
|
||||
Feature freeze ends on the master branch of Kolla projects. We continue to
|
||||
build and deploy the previous release of OpenStack projects, as described in
|
||||
:ref:`early-cycle-stability`.
|
||||
|
||||
Before RC1
|
||||
----------
|
||||
* [all] Communicate end of feature freeze via IRC meeting and openstack-discuss
|
||||
mailing list.
|
||||
|
||||
Prior to creating a release candidate:
|
||||
* [kayobe] Switch ``openstack_release`` and ``override_checkout`` in Kayobe
|
||||
master branch to use the master branch of dependencies.
|
||||
|
||||
* test the code and fix (at a minimum) all critical bugs
|
||||
.. note:: The IPA image still needs to use the previous release in order to
|
||||
be compatible with Ironic.
|
||||
|
||||
* the release notes for each project should be tidied up
|
||||
* example: https://review.opendev.org/c/openstack/kayobe/+/791764
|
||||
|
||||
* [all] Search for TODOs/FIXMEs/NOTEs in the codebases describing tasks to be
|
||||
performed during the new release cycle
|
||||
|
||||
* may include deprecations, code removal, etc.
|
||||
|
||||
* these usually reference either the new cycle or the previous cycle;
|
||||
new cycle may be referenced using only the first letter (for example: V
|
||||
for Victoria).
|
||||
|
||||
R-17: Switch source images to current release
|
||||
---------------------------------------------
|
||||
|
||||
* [kolla ansible] Set ``previous_release`` variables to the previous release.
|
||||
|
||||
* example: https://review.opendev.org/c/openstack/kolla-ansible/+/761835
|
||||
|
||||
* [kolla] Switch source images to use master branches.
|
||||
|
||||
* This patch should include "Depends-On" in the commit message to the Kolla
|
||||
Ansible patch, to avoid skipping a release in upgrade tests
|
||||
* example: https://review.opendev.org/c/openstack/kolla/+/761742
|
||||
|
||||
* [kayobe] Set ``previous_release`` variables to the previous release.
|
||||
|
||||
* example: https://review.opendev.org/c/openstack/kayobe/+/763375
|
||||
|
||||
R-8: Switch binary images to current release
|
||||
--------------------------------------------
|
||||
|
||||
.. note:: Debian does not provide repositories for the in-development release
|
||||
until much later in the cycle.
|
||||
|
||||
* [kolla] Switch CentOS images to use the current in-development release
|
||||
master RDO Delorean repository
|
||||
|
||||
* example: TODO
|
||||
|
||||
* [kolla] Switch Ubuntu binary images to use the current in-development release
|
||||
Ubuntu Cloud Archive (UCA) repository
|
||||
|
||||
* example: https://review.opendev.org/c/openstack/kolla/+/782308
|
||||
|
||||
R-5: Cycle highlights deadline
|
||||
------------------------------
|
||||
|
||||
* [all] Add `cycle highlights
|
||||
<https://docs.openstack.org/project-team-guide/release-management.html#cycle-highlights>`__
|
||||
when requested by the release team. They should be added to the deliverable
|
||||
file for the Kolla project, but also cover Kolla Ansible and Kayobe.
|
||||
|
||||
* example: https://review.opendev.org/c/openstack/releases/+/779482
|
||||
|
||||
R-1: Prepare for RC1 & stable branch creation
|
||||
---------------------------------------------
|
||||
|
||||
As defined by the cycle-trailing release model, a stable branch is created at
|
||||
the point of an RC1 release candidate.
|
||||
|
||||
Prior to creating an RC1 release candidate:
|
||||
|
||||
* [all] Test the code and fix (at a minimum) all critical bugs
|
||||
|
||||
* [all] The release notes for each project should be tidied up
|
||||
|
||||
* this command is useful to list release notes added this cycle:
|
||||
|
||||
@ -84,142 +195,212 @@ Prior to creating a release candidate:
|
||||
|
||||
* example (kolla-ansible): https://review.opendev.org/648685/
|
||||
|
||||
* mark bugs on Launchpad with the correct milestone
|
||||
* example (kayobe): https://review.opendev.org/c/openstack/kayobe/+/788432
|
||||
|
||||
* [kolla][kolla ansible] Mark bugs on Launchpad with the correct milestone
|
||||
|
||||
* this command is useful to check for commits that fixed bugs:
|
||||
|
||||
* ``git log origin/stable/<previous release>..origin/master | grep -i
|
||||
Closes-Bug``
|
||||
|
||||
* update dependencies for source images on master to use release candidates:
|
||||
* [kolla] Update ``OPENSTACK_RELEASE`` variable in ``kolla/common/config.py``
|
||||
to the name of the current in-development release
|
||||
|
||||
* ``./tools/version-check.py --openstack-release $SERIES``
|
||||
* example: https://review.opendev.org/c/openstack/kolla/+/785500
|
||||
|
||||
* this will only work when release candidates have been created for the
|
||||
dependent projects
|
||||
* [kolla] Update versions of independently released projects on master:
|
||||
|
||||
* add ``--include-independent`` to update projects with an independent
|
||||
release cycle
|
||||
* ``./tools/version-check.py --openstack-release $SERIES
|
||||
--include-independent``
|
||||
|
||||
* example (kolla): https://review.opendev.org/647819
|
||||
* example: TODO
|
||||
|
||||
* update ``OPENSTACK_RELEASE`` variable in ``kolla/common/config.py``
|
||||
* [kolla] Switch CentOS images to use the current in-development release
|
||||
stable RDO Delorean repository
|
||||
|
||||
* example (kolla): https://review.opendev.org/689729
|
||||
* example: https://review.opendev.org/c/openstack/kolla/+/787339
|
||||
|
||||
* add `cycle highlights
|
||||
<https://docs.openstack.org/project-team-guide/release-management.html#cycle-highlights>`__
|
||||
when requested by the release team
|
||||
* [kayobe] Synchronise with Kolla Ansible feature flags
|
||||
|
||||
* example (all): https://review.opendev.org/644506/
|
||||
* Clone the Kolla Ansible repository, and run the Kayobe
|
||||
``tools/kolla-feature-flags.sh`` script:
|
||||
|
||||
RC1
|
||||
---
|
||||
.. code-block:: console
|
||||
|
||||
tools/kolla-feature-flags.sh <path to kolla-ansible source>
|
||||
|
||||
* Copy the output of the script, and replace the ``kolla_feature_flags`` list
|
||||
in ``ansible/roles/kolla-ansible/vars/main.yml``.
|
||||
|
||||
The ``kolla.yml`` configuration file should be updated to match:
|
||||
|
||||
.. code-block:: console
|
||||
|
||||
tools/feature-flags.py
|
||||
|
||||
* Copy the output of the script, and replace the list of ``kolla_enable_*``
|
||||
flags in ``etc/kayobe/kolla.yml``.
|
||||
|
||||
* example: https://review.opendev.org/c/openstack/kayobe/+/787775
|
||||
|
||||
* [kayobe] Synchronise with Kolla Ansible inventory
|
||||
|
||||
Clone the Kolla Ansible repository, and copy across any relevant changes. The
|
||||
Kayobe inventory is based on the ``ansible/inventory/multinode`` inventory,
|
||||
but split into 3 parts - top-level, components and services.
|
||||
|
||||
* The top level inventory template is
|
||||
``ansible/roles/kolla-ansible/templates/overcloud-top-level.j2``. It is
|
||||
heavily templated, and does not typically need to be changed. Look out for
|
||||
changes in the ``multinode`` inventory before the ``[baremetal]`` group.
|
||||
|
||||
* The components inventory template is
|
||||
``ansible/roles/kolla-ansible/templates/overcloud-components.j2``.
|
||||
|
||||
This includes groups in the ``multinode`` inventory from the
|
||||
``[baremetal]`` group down to the following text::
|
||||
|
||||
# Additional control implemented here. These groups allow you to control which
|
||||
# services run on which hosts at a per-service level.
|
||||
|
||||
* The services inventory template is
|
||||
``ansible/roles/kolla-ansible/templates/overcloud-services.j2``.
|
||||
|
||||
This includes groups in the ``multinode`` inventory from the following text to
|
||||
the end of the file::
|
||||
|
||||
# Additional control implemented here. These groups allow you to control which
|
||||
# services run on which hosts at a per-service level.
|
||||
|
||||
There are some small changes in this section which should be maintained.
|
||||
|
||||
* example: https://review.opendev.org/c/openstack/kayobe/+/787775
|
||||
|
||||
* [kayobe] Update dependencies to upcoming release
|
||||
|
||||
Prior to the release, we update the dependencies and upper constraints on the
|
||||
master branch to use the upcoming release. This is now quite easy to do,
|
||||
following the introduction of the ``openstack_release`` variable.
|
||||
|
||||
* example: https://review.opendev.org/c/openstack/kayobe/+/787923
|
||||
|
||||
* [kayobe] Synchronise kayobe-config
|
||||
|
||||
Ensure that configuration defaults in ``kayobe-config`` are in sync with
|
||||
those under ``etc/kayobe`` in ``kayobe``. This can be done via:
|
||||
|
||||
.. code-block:: console
|
||||
|
||||
cp -aR kayobe/etc/kayobe/* kayobe-config/etc/kayobe
|
||||
|
||||
Commit the changes and submit for review.
|
||||
|
||||
* example: https://review.opendev.org/c/openstack/kayobe-config/+/787924
|
||||
|
||||
* [kayobe] Synchronise kayobe-config-dev
|
||||
|
||||
Ensure that configuration defaults in ``kayobe-config-dev`` are in sync with
|
||||
those in ``kayobe-config``. This requires a little more care, since some
|
||||
configuration options have been changed from the defaults. Choose a method to
|
||||
suit you and be careful not to lose any configuration.
|
||||
|
||||
Commit the changes and submit for review.
|
||||
|
||||
* example: https://review.opendev.org/c/openstack/kayobe-config-dev/+/788426
|
||||
|
||||
R-0: RC1 & stable branch creation
|
||||
---------------------------------
|
||||
|
||||
RC1 is the first release candidate, and also marks the point at which the
|
||||
stable branch is cut.
|
||||
|
||||
* create RC1 by submitting patches to the releases repository
|
||||
|
||||
* example (kolla): https://review.opendev.org/650236
|
||||
|
||||
* example (kolla-ansible): https://review.opendev.org/650237
|
||||
|
||||
* create stable branches by submitting patches to the releases repository
|
||||
|
||||
* example (kolla): https://review.opendev.org/650411
|
||||
|
||||
* example (kolla-ansible): https://review.opendev.org/650412
|
||||
|
||||
.. note::
|
||||
|
||||
Use the `new-release
|
||||
<https://releases.openstack.org/reference/using.html#using-new-release-command>`__
|
||||
tool for those activities.
|
||||
tool for these activities.
|
||||
|
||||
After RC1
|
||||
---------
|
||||
* [all] Create RC1 and stable branches by submitting patches to the releases
|
||||
repository
|
||||
|
||||
* approve bot-proposed patches to master and the new stable branch
|
||||
* example (kolla & kolla-ansible): https://review.opendev.org/c/openstack/releases/+/786824
|
||||
|
||||
* revert the patch to use release candidates of dependencies on the master
|
||||
branch
|
||||
* example (kayobe): https://review.opendev.org/c/openstack/releases/+/788982
|
||||
|
||||
* example (kolla): https://review.opendev.org/650419
|
||||
* [all] Approve bot-proposed patches to master and the new stable branch
|
||||
|
||||
* revert the patch to switch OPENSTACK_RELEASE in kolla on the master branch
|
||||
* [all] Ensure static links to documentation are enabled
|
||||
|
||||
* example (kolla): https://review.opendev.org/689731
|
||||
* https://opendev.org/openstack/openstack-manuals/src/branch/master/www/project-data
|
||||
|
||||
* switch to use the new release of RDO on the new stable branch (master uses
|
||||
the delorean development packages)
|
||||
* example: https://review.opendev.org/c/openstack/openstack-manuals/+/739206/
|
||||
|
||||
* example (kolla): https://review.opendev.org/651601
|
||||
R+0 to R+13: Finalise stable branch
|
||||
-----------------------------------
|
||||
|
||||
* switch to use the newly tagged container images (the branch for development
|
||||
mode on the new stable branch follows automatically since Victoria)
|
||||
Several tasks are required to finalise the stable branch for release.
|
||||
|
||||
* example (kolla-ansible): https://review.opendev.org/711214
|
||||
* [kolla ansible] Switch to use the newly tagged container images (the branch
|
||||
for development mode on the new stable branch follows automatically since
|
||||
Victoria)
|
||||
|
||||
* update previous release variables on master
|
||||
.. note:: This needs to be done on the stable branch.
|
||||
|
||||
* example (kolla-ansible): https://review.opendev.org/650854
|
||||
.. note:: This requires the images to have been published to quay.io with the
|
||||
new tag.
|
||||
|
||||
* search for TODOs/FIXMEs/NOTEs in the codebases describing tasks to be
|
||||
performed during the next release cycle
|
||||
* example: https://review.opendev.org/c/openstack/kolla-ansible/+/788292
|
||||
|
||||
* may include deprecations, code removal, etc.
|
||||
* [kolla] Switch CentOS images to use the CentOS Cloud SIG repository for the
|
||||
new release
|
||||
|
||||
* these usually reference either the new cycle or the previous cycle;
|
||||
new cycle may be referenced using only the first letter (for example: V
|
||||
for Victoria).
|
||||
.. note:: This needs to be done on the stable branch.
|
||||
|
||||
After OpenStack Final Release
|
||||
-----------------------------
|
||||
* example: https://review.opendev.org/c/openstack/kolla/+/788490
|
||||
|
||||
* update dependencies for source images on master to use final releases:
|
||||
* [kolla] Switch Debian binary images to use the Debian OpenStack repository
|
||||
for the new release
|
||||
|
||||
* ``./tools/version-check.py --openstack-release $SERIES``
|
||||
.. note:: This needs to be done on the master branch and stable branch.
|
||||
|
||||
* example (kolla): https://review.opendev.org/651605/
|
||||
* example: https://review.opendev.org/c/openstack/kolla/+/788304
|
||||
|
||||
RC2+
|
||||
----
|
||||
R+0 to R+13: Further release candidates and final release
|
||||
---------------------------------------------------------
|
||||
|
||||
Further release candidates may be created on the stable branch as necessary in
|
||||
a similar manner to RC1.
|
||||
|
||||
Final Releases
|
||||
--------------
|
||||
Once the stable branches are finalised, further release candidates may be
|
||||
created as necessary in a similar manner to RC1.
|
||||
|
||||
A release candidate may be promoted to a final release if it has no critical
|
||||
bugs against it.
|
||||
|
||||
* create final release by submitting patches to the releases repository
|
||||
* [all] Create final release by submitting patches to the releases repository
|
||||
|
||||
* example (kolla): TODO
|
||||
* example: https://review.opendev.org/c/openstack/releases/+/769328
|
||||
|
||||
* example (kolla-ansible): TODO
|
||||
After final release, projects enter the :ref:`stable-branch-lifecycle` with a
|
||||
status of Maintained.
|
||||
|
||||
* ensure static links to documentation are enabled
|
||||
R+13 marks the 3 month deadline for the release of cycle-trailing projects.
|
||||
|
||||
* https://opendev.org/openstack/openstack-manuals/src/branch/master/www/project-data
|
||||
.. _stable-branch-lifecycle:
|
||||
|
||||
* example for Ussuri: https://review.opendev.org/739206
|
||||
Stable Branch Lifecycle
|
||||
=======================
|
||||
|
||||
Stable Releases
|
||||
===============
|
||||
The lifecycle of stable branches in OpenStack is described in the `project team
|
||||
guide <https://docs.openstack.org/project-team-guide/stable-branches.html>`__.
|
||||
The current status of each branch is published on the `releases
|
||||
<https://releases.openstack.org/>`__ site.
|
||||
|
||||
Stable branch releases should be made periodically for each supported stable
|
||||
branch, no less than once every 45 days.
|
||||
Maintained
|
||||
----------
|
||||
|
||||
* check for new releases of dependencies
|
||||
Releases should be made periodically for each maintained stable branch, no less
|
||||
than once every 45 days.
|
||||
|
||||
* ``tools/version_check.py``
|
||||
|
||||
* example (kolla): https://review.opendev.org/652674/
|
||||
|
||||
* create stable releases by submitting patches to the releases repository
|
||||
* Create stable releases by submitting patches to the releases repository
|
||||
|
||||
* follow SemVer guidelines
|
||||
|
||||
@ -227,17 +408,9 @@ branch, no less than once every 45 days.
|
||||
|
||||
* example (kolla-ansible): https://review.opendev.org/650412
|
||||
|
||||
* mark milestones on Launchpad as released
|
||||
* Mark milestones on Launchpad as released
|
||||
|
||||
* create new milestones on Launchpad for the next stable releases
|
||||
|
||||
Branch Lifecycle
|
||||
================
|
||||
|
||||
The lifecycle of stable branches in OpenStack is described in the `project team
|
||||
guide <https://docs.openstack.org/project-team-guide/stable-branches.html>`__.
|
||||
The current status of each branch is published on the `releases
|
||||
<https://releases.openstack.org/>`__ site.
|
||||
* Create new milestones on Launchpad for the next stable releases
|
||||
|
||||
Extended Maintenance (EM)
|
||||
-------------------------
|
||||
|
Loading…
Reference in New Issue
Block a user