https://blueprints.launchpad.net/fuel/+spec/separate-mos-from-linux
To provide highest quality Mirantis OpenStack should separate OS lifecycle and Cloud lifecycle management. Meanwhile OS Updates shouldn’t break Mirantis OpenStack functionality and vice versa.
This specification introduces a clear separation between base distro (Red Hat or Debian based Linux OSes), and the Mirantis OpenStack distribution (MOS). All software packages deployed by Fuel are divided into following categories based on their relation to the specific base distro and OpenStack distribution being deployed:
Note
Downgraded packages with upstream version lower than the version available in the base distro are not allowed.
Different releases of MOS can put the same software package in different categories.
All kinds of divergence from the base distro should be kept to a minimum. As many of MOS dependencies as possible should be satisfied by upstream packages from the supported release of the base distro. When possible, MOS patches and MOS specific packages should be contributed back to base distros.
Released MOS packages will be distributed as part of Fuel ISO image. Upstream packages, as well as any other IP protected by respective OS vendors, will not be the included in Fuel ISO images. Regular updates to the MOS OpenStack distribution will be delivered through online MOS mirrors.
MOS mirrors should be organized in the same way as base distro mirrors. MOS mirrors should follow industry standards. The structure of a mirror should be done in the same way as base distro mirrors.
Every supported OS will have own set of repositories containing MOS packages per release (mos6.1, mos7.0 etc.) These repositories must contain only packages with MOS specific modifications, and no upstream packages from the corresponding base distro.
Mirror should be publicly and globally available and distributed. User should be able to create and maintain local copies of base distro and MOS mirrors. This will allow user to use repositories in completely isolated environments or create own freezed mirrors to pass extended validation before package update roll-out across production environment.
/
+--+centos
|  |
|  +--+6
|  |  |
|  |  +--+mos6.0
|  |  |
|  |  +--+mos6.1
|  |
|  +--+7
|     |
|     +--+mos7.0
|     |
|     +--+mos7.1
|
+--+ubuntu
   |
   +--+dists
   |
   +--+pool
   |
   +--+...
MOS mirror should include several repositories (updates, security, proposed) built in the same way as base OS mirror (Debian or Ubuntu). Repository sections are organized in the same way (main, restricted) according to package licenses (non-free). The meaning of components for Debian mirror resembles the meaning of components of the base OS distribution mirror.
$(OS_MIRROR)                 $(MOS_MIRROR)
+                            +
|                            |
+--+ubuntu                   +--+ubuntu
   |                            |
   +--+dists                    +--+dists
   |  |                         |  |
   |  +--+precise-backport      |  +--+mos6.1-proposed
   |  |                         |  |
   |  +--+precise-proposed      |  +--+mos6.1-security
   |  |                         |  |
   |  +--+precise-security      |  +--+mos6.1-updates
   |  |                         |  |
   |  +--+precise-updates       |  +--+mos6.1
   |  |                         |  |
   |  +--+precise               |  +--+mos7.0-proposed
   |  |                         |  |
   |  +--+trusty-backport       |  +--+mos7.0-security
   |  |                         |  |
   |  +--+trusty-proposed       |  +--+mos7.0-updates
   |  |                         |  |
   |  +--+trusty-security       |  +--+mos7.0
   |  |                         |
   |  +--+trusty-updates        +--+indices
   |  |                         |  |
   |  +--+trusty                |  +--+...
   |                            |
   +--+indices                  +--+pool
   |  |                         |  |
   |  +--+...                   |  +--+main
   |                            |  |  |
   +--+pool                     |  |  +--+a
   |  |                         |  |  |
   |  +--+main                  |  |  +--+...
   |  |                         |  |  |
   |  +--+multiverse            |  |  +--+z
   |  |                         |  |
   |  |--+restricted            |  |--+restricted
   |  |                         |     |
   +  |--+universe              |     +--+a
   |                            |     |
   |--+...                      |     +--+...
                                |     |
                                |     +--+z
                                |
                                +--+project
                                   |
                                   +--+mos-archive-keyring.gpg
                                   |
                                   +--+mos-archive-keyring.sig
MOS mirror should include several repositories (os, updates, Fasttrack) built in the same way as base distro mirror (Red Hat or CentOS).
$(OS_MIRROR)                           $(MOS_MIRROR)
+                                      +
|                                      |
+--+centos-6                           +--+centos-6
|  |                                   |  |
|  +--+...                             |  +--+mos6.1
|                                      |  |
+--+centos-7                           |  +--+mos7.0
   |                                   |     |
   +--+7                               |     +--+os
      |                                |     |  |
      +--+os                           |     |  +--+x86_64
      |  |                             |     |     |
      |  +--+x86_64                    |     |     +--+Packages
      |     |                          |     |     |  |
      |     +--+Packages               |     |     |  +--+*.rpm
      |     |  |                       |     |     |
      |     |  +--+*.rpm               |     |     +--+RPM-GPG-KEY-MOS7.0
      |     |                          |     |     |
      |     +--+RPM-GPG-KEY-CentOS-7   |     |     +--+repodata
      |     |                          |     |        |
      |     +--+repodata               |     |        +--+*.xml,*.gz
      |        |                       |     |
      |        +--+*.xml,*.gz          |     +--+updates
      |                                |        |
      +--+updates                      |        +--+x86_64
         |                             |           |
         +--+x86_64                    |           +--+Packages
            |                          |           |  |
            +--+Packages               |           |  +--+*.rpm
            |  |                       |           |
            |  +--+*.rpm               |           +--+repodata
            |                          |              |
            +--+repodata               |              +--+*.xml,*.gz
               |                       |
               +--+*.xml,*.gz          +--+centos-7
                                          |
                                          +--+mos7.1
                                          |
                                          +--+mos8.0
Handling multiple package repositories in Nailgun [1] will be expanded to allow user to set priorities during deployment.
Default repository priorities are arranged so that packages from MOS repositories are preferred over packages from base distro. On Debian based systems, the force-downgrade APT pinning priorities are used for MOS repositories to make sure that, when a package is available in a MOS repository, it is always preferred over the package from base distro, even if the version in MOS repository is lower.
Build system should allow developers to build custom packages. These packages should be placed into special repository which can be specified in Nailgun [1] to deliver these packages to an environment. APT pinning priority for these repositories should be higher than base distro and MOS repositories. Accordingly, Yum repository priority value must be lower than base distro and MOS repositories.
In the future, this functionality should be exposed to the community allowing any community engineer (e.g. nova, cinder) to specify their own git refspec (repository and commit). The build system should be able to build packages and provide a link which can be passed through Nailgun.
Holdback repository is a measure aimed to ensure the highest quality of MOS product. If there is an upstream package that breaks the product, and this problem cannot be fixed in a timely manner, MOS team publishes the package proven stable to the “mosXX-holdback” repository. This repository should be automatically configured on all installations with priority higher than base distro repositories.
The case when base distro vendor releases fixed version of a problem package, must be covered by MOS system tests.
Ideally, upstream updates shouldn’t break the functionality of Product. The number of packages in “mosXX-holdback” should be zero. Even if package is put in repository, MOS team should contact base distro vendor to report the regression. Package Update should be discarded before it appears in Update repository. If package is supposed to appear in update repository, MOS team should update “mosXX-holdback” repository before that.
Testing in “mosXX-holdback” repository should be done against every package as next release may fix the regression that might occur. Once regression is fixed in upstream the package should be removed from “mosXX-holdback” repository.
Package version string for a MOS specific or divergent package must not include registered trademarks of base distro vendors, and should include “mos” keyword.
Every new revision of a MOS specific or divergent package targeted to a MOS release (including corresponding update repository) must have a package version greater than or equal to the versions of the same package in all previous releases of MOS (base, update, security repositories), as well as versions of the same package previously published in any repos for this MOS release.
For example, there must be no package version downgrades in the following MOS release progression (where 6.1.1 matches the state of update repository at the time of 6.1.1 maintenance release):
6.0 <= 6.0.1 <= 6.1 <= 6.1.1 <= 6.1.2 <= 7.0
Package version of a divergent package (including upgraded and holdback packages) must be constructed in a way that would allow the upstream package with the same software version to be automatically considered for upgrade by package management system as soon as the divergent package is removed from the MOS repositories. This will simplify phasing out divergent packages in favor of upstream packages between major MOS releases, but, thanks to repo priorities defined above, will not lead to new upstream packages superceding upgraded packages available from MOS repos when applying updates.
Every new revision of a divergent package must have a package version greater than previous revisions of the same package that were published to the same repository for that MOS release. It’s version should be lower than version of the corresponding upstream package.
When the same package version is ported from one MOS release to another without modifications (i.e. same upstream version and same set of patches), new package version should include full package version from the original MOS release.
Versioning requirements defined in this section apply to all software packages in all MOS repositories for Debian based distros. The standard terms defined in Debian Policy[7]_ are used to describe package version components: epoch, upstream version, Debian revision.
Upstream version of a package should exactly match the software version, without suffixes. Introducing epoch or increasing epoch relative to base distro should be avoided.
Debian revision of a MOS package should use the following format:
<revision>~<base-distro-release>+mos<subrevision>
In MOS specific packages, revision must always be “1”:
fuel-nailgun_6.1-1~u14.04+mos1
In divergent packages, revision should include as much of the debian revision of the corresponding upstream package as possible while excluding the base distro vendor’s trademarks, and including target distribution version:
qemu_2.1.0-1           -> qemu_2.1.0-1~u14.04+mos1
ohai_6.14.0-2.3ubuntu4 -> ohai_6.14.0-2.3~u14.04+mos1
Note
Do not start the debian revision with “0~” since it makes the package version LOWER than the corresponding upstream version. For example, qemu_2.1.0-0~u14.04+mos1 does not satisfy a “Depends: qemu >= 2.1.0” requirement.
Attention
In case of Ubuntu specific packages named as 0ubuntuX it would be not enough to just bump the revision by the scheme described above, as the resulting version still will be lower than the original one. You should change it the following way: 0ubuntuX -> 0u~u14.04+mos
Subrevision numbering starts from 1. Subsequent revisions of a package using the same upstream version and based on the upstream package with the same debian revision should increment the subrevision:
ohai_6.14.0-2.3~u14.04+mos2
ohai_6.14.0-2.3~u14.04+mos3
Subsequent revision of a package that introduces a new upstream version or new base distro package revision should reset the subrevision back to 1:
ohai_6.14.0-3ubuntu1 -> ohai_6.14.0-3~u14.04+mos1
Once a MOS release reaches GA, the primary package repository for the release is frozen, and subsequent updates are published to the updates repositories.
Most of the time, only a small subset of modifications (including patches, metadata changes, etc.) will be backported to updates for old MOS releases. When updated package includes only a subset of modifications, its version should include the whole package version from the primary repository, followed by a reference to the targeted MOS release, and an update subrevsion, both separated by “+”:
mos6.1:         qemu_2.1.0-1~u14.04+mos1
mos7.0:         qemu_2.1.0-1~u14.04+mos1
mos7.1:         qemu_2.1.0-1~u14.04+mos2
mos6.1-updates: qemu_2.1.0-1~u14.04+mos1+mos6.1+1
mos7.0-updates: qemu_2.1.0-1~u14.04+mos1+mos7.0+1
If the whole package along with all included modifications is backported from current release to updates for an old MOS release, its version should include the whole package version from the current release, followed by a reference to the targeted MOS release separated by “~”, and an update subrevision, separated by “+”:
mos6.1:         qemu_2.1.0-1~u14.04+mos1
mos7.0:         qemu_2.1.0-1~u14.04+mos1
mos7.1:         qemu_2.1.0-1~u14.04+mos2
mos6.1-updates: qemu_2.1.0-1~u14.04+mos2~mos6.1+1
mos7.0-updates: qemu_2.1.0-1~u14.04+mos2~mos7.0+1
Same rule applies if modifications include an upgrade to a newer software version:
mos6.1:         qemu_2.1.0-1~u14.04+mos1
mos7.0:         qemu_2.1.0-1~u14.04+mos1
mos7.1:         qemu_2.2+dfsg-5exp~u14.04+mos3
mos6.1-updates: qemu_2.2+dfsg-5exp~u14.04+mos3~mos6.1+1
mos7.0-updates: qemu_2.2+dfsg-5exp~u14.04+mos3~mos7.0+1
All MOS specific and divergent packages must have the following metadata:
Example of a valid debian/changelog entry:
keystone (2014.2.3-1~u14.04+mos1) mos6.1; urgency=low
 * Source commit: 17f8fb6d8d3b9d48f5a4206079c18e84b73bf36b
 * Build commit: 8bf699819c9d30e2d34e14e76917f94daea4c67f
-- Mirantis OpenStack Team <mos@mirantis.com> Sat, 21 Mar 2015 15:08:01 -0700
If the package is a backport from a different release of a base distro (e.g. a backport of a newer software version from Ubuntu 14.10 to Ubuntu 14.04), the exact package version which the backport was based on must also be specified in the debian/changelog entry, along with the URL where the source package for that package version can be obtained from.
Following types of URLs may be used, in the order of preference:
To deliver high quality of product MOS teams should produce package updates during Product lifecycle when it’s required.
Packaging lifecycle should follow the MOS product lifecycle (Feature Freeze, Soft Code Freeze, Hard Code Freeze, Release, Updates).
MOS mirror should be modified on Hard Code Freeze announcement. A new MOS version should be created in order to allow developers to continue on new release.
After GA release all packages should be placed in updates or security repository
V^                                                    +---------------------+
 |                                                    |7.1-updates
 |                                                    |
 |                                                    |
 |                                      +-----------------------------------+
 |                                      |8.0-dev      |
 |                                      |             |
 |                                      |             |
 |                        +-------------------------------------------------+
 |                        |6.1-updates  |             |
 |                        |             |             |
 |                        |             |             |
 |            +-------------------------+-------------+---------------------+
 |            |7.1-dev    |            7.1-HCF       7.1 GA
 |            |           |
 |            |           |
 +------------+-----------+------------------------------------------------->
 6.1 dev    6.1 HCF     6.1 GA                                             t
Patches for security vulnerabilities should be placed in security repository. They are designed to change the behavior of the package as little as possible. In fact, the minimum required to resolve the security problem.
Package flow should be specified from building package, incubating package in proposed repository (mos6.1-proposed as a sample), acceptance testing, security testing before it will appear in updates in MOS mirror.
As a part of a product lifecycle there should be periodical system tests that verify functionality of MOS against:
If the system test against proposed[2]_ or Fasttrack repositories[3]_ reveals one or several packages that break MOS functionality, MOS teams must provide one of the following solutions:
Also, any package that failed the system test, must be reflected on the release status page.
To ensure that MOS customers have full info on the release stability, all packages that produce system test failures must be also reported in several different ways:
Fuel DEB packages build routine will be disabled by default, and kept for Fuel CI purposes only (nightly and test Product builds). Release Product ISO will contain Fuel DEB packages from MOS repository. Updates to Fuel DEB packages will be consumed from the MOS mirror directly on master node. [1]
Explicit list of Fuel DEB packages is below:
All Dockerfile configs will be adjusted to include both upstream and MOS repositories.
ISO assembly module will be adjusted to exclude all parts mentioned above.
There’s various reasoning behind having a local mirrors of base distro, from security considerations, to making deployments faster and more reliable. To support such installation cases we will implement the Linux console script that mirrors the public base distro and MOS mirrors to a given location, allowing to put these local sources as input for the appropriate menu entry of Fuel “Settings” tab on UI, or specify directly via Fuel CLI. In case of deb-based base distro, MOS requires packages from multiple sections of a given distribution (main, universe, multiverse, restricted), so the helper script will mirror all packages from components specified above. Requirements:
There is no alternative to the repositories separation approach due to considerations related to distribution policies of major OS vendors. Regarding the helper script to download base distro repositories, there could be a different approach implemented, by downloading only particular packages that required by MOS. However, we consider that providing a full upstream repository would make customer experience a bit better, especially in cases when additional upstream packages that are not a part of MOS need to be installed).
None
None
When Fuel master node is upgraded to a version that supports Linux distro separation, package repositories for old versions of MOS deployed by previous version of Fuel will keep using the old mirror structure. Package repositories for the new versions of MOS will use the structure defined in this specification.
Also see support-ubuntu-trusty [5] on the upgrade impact of switching the base Ubuntu version from 12.04 (precise) to 14.04 (trusty).
None
None
In case of offline installations, user will be required to create a copy of MOS and base distro mirrors by using a script described in this document.
If packages are consumed from remote 3rd party servers, overall deployment time may be increased. In case of offline installation, no deployment speed degradation is expected.
Changes described in this document allow to increase product flexibility, by making possible to choose an operating system and install it independent of MOS.
None
Create local OS mirrors for CI purposes
Change Fuel make system to exclude DEB packages from ISO
Create MOS mirror with the same structure as OS vendor
Deb package build process should be changed. All packages should be put in MOS mirror
Create CI Jobs to test against OS vendor SRU [2]
Adapt system tests of Ubuntu for the new repositories workflow
Implement script for creating of local base distro and MOS mirrors on master node.
None
As this document introduces structural changes to the ISO composition and MOS mirrors layout, testing procedure must reflect the updated workflow for deploying Ubuntu environments described in this blueprint. [1]
The documentation should cover: