Channels¶
Canonical Kubernetes uses the concept of channels
to make sure you always get
the version of Kubernetes you are expecting, and that future upgrades can be
handled with minimum, if any, disruption.
Choosing the right channel¶
When installing or updating Canonical Kubernetes you can (and should in most cases) specify a channel. The channel specified is made up of two components; the track and the risk level.
The track matches the minor version of upstream Kubernetes. For example,
specifying the 1.32
track will match upstream releases of the same minor
version (“1.32.0”, “1.32.1”, “1.32.x” etc.). Releases of Canonical Kubernetes
closely follow the upstream releases and usually follow within 24 hours.
The ‘risk level’ component of the channel is one of the following:
stable
: Matches upstream stable releasescandidate
: Holds the release candidates of the snapbeta
: Tracks the beta releases - expect bugsedge
: Experimental release including upstream alpha releases
Note that for each track, not all risk levels are guaranteed to be available.
For example, there may be a new upstream version in development which only has
an edge
level. For a mature release, there may no longer be any beta
or
candidate
. In these cases, if you specify a risk level which has no releases for
that track the snap system will choose the closest available release with a
lower risk level. Whatever risk level specified is the maximum risk level
of the snap that will be installed - if you choose candidate
you will never
get edge
for example.
For all snaps, you can find out what channels are available by running the
info
command, For example:
snap info k8s
More information can be found in the Snapcraft documentation
Updates and switching channels¶
Updates for upstream patch releases will happen automatically by default. For
example, if you have selected the channel 1.32-classic/stable
, your snap will refresh
itself regularly keeping your cluster up-to-date with the latest patches.
For deployments where this behaviour is undesirable you are given the option to
postpone, schedule or even block automatic updates.
The Snap refreshes documentation page outlines how to configure these options.
To change the channel of an already installed snap, the refresh
command can
be used:
sudo snap refresh k8s --channel=<new-channel>
Warning
Changing the channel of an installed snap could result in loss of service. Please check any release notes or upgrade guides first!
Which channel is right for me?¶
Choosing the most appropriate channel for your needs depends on a number of factors. We can give some general guidance for the following cases:
I want to always be on the latest stable version matching a specific upstream K8s release (recommended).
Specify the release, for example: --channel=1.32-classic/stable
.
I want to test-drive a pre-stable release
Use --channel=<next_release>/edge
for alpha releases.
Use --channel=<next_release>/beta
for beta releases.
Use --channel=<next_release>/candidate
for candidate releases.
I am waiting to test a bug fix on Canonical Kubernetes
Use --channel=<release>/edge
.
I am waiting for a bug fix from upstream Kubernetes
Use --channel=<release>/candidate
.