Microk8s is a snap deploying Kubernetes. The MicroK8s snap closely follows upstream Kubernetes, so understanding a bit about the Kubernetes release cycle is helpful for more insight into MicroK8s releases.
Upstream Kubernetes ships a new release series (e.g. 1.27.x) approximately every three months. Prior release series may get periodic bugfix releases: for example, the latest 1.24 release is 1.24.8.
When installing the MicroK8s you can specify a channel. The channel specified is made up of two components; the track and the risk level. For example to install MicroK8s v1.27 with risk level set to stable you need to:
sudo snap install microk8s --classic --channel=1.27/stable
The track denotes the upstream Kubernetes version while the risk level reflects the maturity level of the release. The
stable risk level indicates that your cluster is updated when the MicroK8s team decides a release is ready and no issues have been revealed by users running the same revision on riskier branches (edge and candidate).
All the currently available channels are shown if you run
snap info microk8s:
... channels: 1.26/stable: v1.26.3 2023-03-30 (4959) 177MB classic 1.26/candidate: v1.26.3 2023-03-30 (4959) 177MB classic 1.26/beta: v1.26.3 2023-03-30 (4959) 177MB classic 1.26/edge: v1.26.3 2023-04-07 (5063) 177MB classic latest/stable: v1.26.3 2023-03-30 (4959) 177MB classic latest/candidate: v1.27.0 2023-04-12 (5100) 177MB classic latest/beta: v1.27.0 2023-04-12 (5100) 177MB classic latest/edge: v1.27.0 2023-04-11 (5100) 177MB classic dqlite/stable: – dqlite/candidate: – dqlite/beta: – dqlite/edge: v1.16.2 2019-11-07 (1038) 189MB classic 1.27-strict/stable: v1.27.0 2023-04-12 (5107) 177MB - 1.27-strict/candidate: v1.27.0 2023-04-12 (5107) 177MB - 1.27-strict/beta: v1.27.0 2023-04-12 (5107) 177MB - 1.27-strict/edge: v1.27.0 2023-04-11 (5107) 177MB - 1.27/stable: v1.27.0 2023-04-12 (5101) 177MB classic 1.27/candidate: v1.27.0 2023-04-12 (5101) 177MB classic 1.27/beta: v1.27.0 2023-04-12 (5101) 177MB classic 1.27/edge: v1.27.0 2023-04-11 (5101) 177MB classic 1.26-strict/stable: v1.26.1 2023-02-23 (4596) 176MB - 1.26-strict/candidate: v1.26.3 2023-04-02 (5017) 177MB - 1.26-strict/beta: v1.26.3 2023-04-02 (5017) 177MB - 1.26-strict/edge: v1.26.3 2023-03-30 (5017) 177MB - 1.25-strict/stable: v1.25.8 2023-04-11 (5019) 175MB - 1.25-strict/candidate: v1.25.8 2023-04-01 (5019) 175MB - 1.25-strict/beta: v1.25.8 2023-04-01 (5019) 175MB - 1.25-strict/edge: v1.25.8 2023-03-30 (5019) 175MB - 1.25-eksd/stable: v1.25-10 2023-04-07 (5052) 175MB classic 1.25-eksd/candidate: v1.25-10 2023-04-05 (5052) 175MB classic 1.25-eksd/beta: v1.25-10 2023-04-05 (5052) 175MB classic 1.25-eksd/edge: v1.25-10 2023-04-07 (5078) 175MB classic 1.25/stable: v1.25.8 2023-04-03 (5016) 175MB classic 1.25/candidate: v1.25.8 2023-04-01 (5016) 175MB classic 1.25/beta: v1.25.8 2023-04-01 (5016) 175MB classic 1.25/edge: v1.25.8 2023-04-07 (5064) 175MB classic 1.24-eksd/stable: v1.24-14 2023-04-10 (5044) 171MB classic 1.24-eksd/candidate: v1.24-14 2023-04-01 (5044) 171MB classic 1.24-eksd/beta: v1.24-14 2023-04-01 (5044) 171MB classic 1.24-eksd/edge: v1.24-14 2023-04-11 (5088) 171MB classic 1.24/stable: v1.24.12 2023-03-20 (4950) 225MB classic 1.24/candidate: v1.24.12 2023-03-20 (4950) 225MB classic 1.24/beta: v1.24.12 2023-03-20 (4950) 225MB classic 1.24/edge: v1.24.12 2023-03-17 (4950) 225MB classic 1.23-eksd/stable: v1.23-19 2023-04-09 (5043) 167MB classic 1.23-eksd/candidate: v1.23-19 2023-03-31 (5043) 167MB classic 1.23-eksd/beta: v1.23-19 2023-03-31 (5043) 167MB classic 1.23-eksd/edge: v1.23-19 2023-04-10 (5086) 167MB classic 1.23/stable: v1.23.17 2023-03-30 (4916) 213MB classic 1.23/candidate: v1.23.17 2023-03-29 (4916) 213MB classic 1.23/beta: v1.23.17 2023-03-29 (4916) 213MB classic 1.23/edge: v1.23.17 2023-03-16 (4916) 213MB classic 1.22-eksd/stable: v1.22-24 2023-04-08 (5041) 164MB classic 1.22-eksd/candidate: v1.22-24 2023-03-31 (5041) 164MB classic 1.22-eksd/beta: v1.22-24 2023-03-31 (5041) 164MB classic 1.22-eksd/edge: v1.22-24 2023-03-31 (5041) 164MB classic 1.22/stable: v1.22.17 2022-12-18 (4374) 187MB classic 1.22/candidate: v1.22.17 2022-12-10 (4374) 187MB classic 1.22/beta: v1.22.17 2022-12-10 (4374) 187MB classic 1.22/edge: v1.22.17 2023-03-16 (4915) 187MB classic 1.21/stable: v1.21.13 2022-07-20 (3410) 191MB classic 1.21/candidate: v1.21.13 2022-07-09 (3410) 191MB classic 1.21/beta: v1.21.13 2022-07-09 (3410) 191MB classic 1.21/edge: v1.21.13 2022-06-08 (3410) 191MB classic ...
If you do not set a channel at install time…
snap install microk8s --classic
…the snap install will default to the latest current stable version, e.g. ‘1.27/stable’.
In this case you will get periodic snap updates to the current stable release at the time of the installation. Updates will not include a new series, only patch releases. This means that MicroK8s should continue running normally, even when a new series is released.
To use a specific version of Kubernetes, you can use the
--channel option. For example, to install MicroK8s and let it follow the
v1.24 stable release series you can run:
snap install microk8s --classic --channel=1.24/stable
In this case you will only receive updates for the 1.24 release of Kubernetes, and MicroK8s will never upgrade to 1.25, unless you explicitly refresh the snap.
*/stable channels serve the latest stable upstream Kubernetes release of the respective release series. Upstream releases are propagated to the MicroK8s snap in about a week. This means your MicroK8s will upgrade to the latest upstream release in your selected channel roughly one week after the upstream release.
*/beta channels get updated within hours of an upstream release. Getting a MicroK8s deployment pointing to
1.26/beta is as simple as:
snap install microk8s --classic --channel=1.26/beta
*/edge channels get updated on each MicroK8s patch or upstream Kubernetes patch release.
Keep in mind that edge and beta are snap constructs and do not relate to specific Kubernetes release names.
On tracks where no stable Kubernetes release is available, MicroK8s ships pre-release versions under the following scheme:
1.26/edge) holds the alpha upstream releases.
1.26/beta) holds the beta upstream releases.
1.26/candidate) holds the release candidate
of upstream releases.
Pre-release versions will be available the same day they are released upstream.
For example, to test your work against the alpha
v1.26 release simply run:
sudo snap install microk8s --classic --channel=1.26/edge
However, be aware that pre-release versions may require you to configure the Kubernetes services on your own.
MicroK8s now supports a track which conforms to the
strictmode of snap installs. Strictly confined MicroK8s is installed via the tracks that include strict in their name. For example:
snap install microk8s --channel 1.26-strict
For more information on the differences between strictly-confined MicroK8s and the classic version, please see this explanation.
The single question you need to focus on is what channel should be used below:
sudo snap install microk8s --classic --channel=<which_channel?>
Here are some suggestions for the channel to use based on your needs:
I want to always be on the latest stable Kubernetes.
I want to always be on the latest release in a specific upstream K8s release.
I want to test-drive a pre-stable release.
--channel=<next_release>/edgefor alpha releases.
--channel=<next_release>/betafor beta releases.
--channel=<next_release>/candidatefor candidate releases.
I am waiting for a bug fix on MicroK8s:
I am waiting for a bug fix on upstream Kubernetes:
It is possible to change the snap channel using the refresh command. E.g. to transition to the latest alpha:
sudo snap refresh microk8s --channel=latest/edge
By default, snaps are set to check for updates and automatically refresh to the
latest version (for your selected channel) four times per day. For deployments where this behavior is undesirable you are given the option to postpone, schedule or even block automatic updates. The snap refreshes page outlines how to configure these options.