MicroK8s
Introduction
Portainer consists of two elements, the Portainer Server and the Portainer Agent. Both elements run as lightweight containers on Kubernetes. This document will outline how to connect Portainer to your existing infrastructure to deploy MicroK8s and install the Portainer Agent. If you do not have a working Portainer Server instance yet, please refer to the Portainer Server installation guide first.
Prerequisites
In order to connect to and deploy MicroK8s and the Portainer Agent on your existing infrastructure, you will need:
One or more Linux-based machines on which MicroK8s will be deployed. We have primarily tested on Ubuntu 20.04 LTS but most comparable Linux distributions should work. These machines can be bare metal servers or virtual machines.
Root or sudo-level SSH access to the above machines on port
22
. This is needed in order to install MicroK8s. Portainer supports both password-based and key-based authentication.The
snap
tool installed on the above machines. You can find installation instructions for most Linux distributions at the Snapcraft website. Thesnap
tool is used to install MicroK8s and any selected addons.Communication between the Portainer Server and the above machines, as well as communication between the individual machines in the cluster. This is to ensure the Portainer Server can reach the machines both for the initial installation and for communication with the Portainer Agent once the cluster is up and running, and so that the cluster nodes can communicate with each other.
What to expect
By necessity, our MicroK8s deployment makes some configuration decisions for you.
The Portainer Agent is deployed using NodePort, on port
30778
.There may be some configuration differences between versions of MicroK8s deployed. One notable difference is from version 1.25, if the
ingress
addon is installed an additional ingress namednginx
is configured. This does not occur on version 1.24. We recommend referring to the MicroK8s release notes for further detail.The deployment does not configure any storage classes on your cluster (unless the
hostpath-storage
addon is installed, though this is not recommended for multiple node clusters). Due to the vast amount of potential storage class configurations, this is not something we currently provide automatically. We recommend configuring a storage class once provision completes.
Deployment
To create and deploy MicroK8s and the Portainer Agent to your machines, from the menu select Environments then click Add Environment.
Select Create a Kubernetes cluster and click Start wizard.
If you have not yet configured a set of SSH credentials, you will be asked to provide them now. If you already have a credential set configured, you can skip to cluster configuration.
Add SSH credentials
Fill in the fields based on the table below:
Field/Option | Overview |
---|---|
Credentials name | Enter a name for this credential set. This is how it will be listed in Portainer. |
SSH username | Enter the username for your SSH account. |
SSH password | Enter the password for your SSH account. You can leave this field blank if you intend to use SSH key authentication. |
Use SSH key authentication | Enable this toggle to use SSH key authentication instead of password authentication. |
SSH private key passphrase | If your SSH private key is encrypted, provide the passphrase here. |
SSH private key | Paste your SSH private key in this field. |
You can also choose to generate a new SSH key pair by clicking the Generate new RSA SSH key pair button, or upload an existing private key by clicking the Upload SSH private key button. You can find more detailed instructions for generating a new SSH key in our SSH credentials documentation.
Once you have entered your credentials click Add credentials. The credential set will be saved under the name you entered, and you will be taken to the cluster configuration.
Configure your cluster
Once you have a set of credentials configured, you can proceed to configuring your cluster. Fill out the fields based on the table below:
Field/Option | Overview |
---|---|
Name | Enter a name for your environment. This is how the environment will appear in Portainer. |
Credentials | Select the set of SSH credentials to use from the dropdown. |
Node IP list | Enter a comma-separated or line-separated list of the IP addresses for the machines that will make up your cluster. You can also specify a range of IP addresses with a hyphen. |
Portainer will configure a maximum of 3 control plane nodes in your environment, based on the first three IP addresses provided. The rest will be configured as worker nodes. For clusters with 1 or 2 nodes total, the first node will be configured as a control plane and the rest as worker nodes.
Once you have selected a credential set and entered the node IPs, you can click Test connections to ensure the credentials work for all the IP addresses and that they are reachable from the Portainer Server instance.
You can now proceed to configuring MicroK8s itself. Fill out the fields based on the table below:
Field/Option | Overview |
---|---|
Kubernetes version | Select the version of MicroK8s to deploy on your cluster. Selecting |
Addons | Optionally select one or more addons to deploy alongside the MicroK8s installation. |
Custom template | Optionally select a custom template to deploy on your cluster once the MicroK8s and Portainer Agent installations are complete. This is handy for pre-loading a new environment with your applications. The template will be deployed in the default namespace unless the template specifies a namespace to use. |
A note about MicroK8s versions
We have tested deployments of MicroK8s versions 1.24
, 1.25
and 1.26
. If you select latest/stable
as the version and this has moved on from our tested versions, we cannot guarantee that the deployment will work successfully.
In addition, we are aware of an issue with MicroK8s versions 1.25
and 1.26
where the metrics-server
addon may not always start successfully. If you run into this issue we have provided a workaround patch you can run on a master node on your new cluster:
Please note that this patch exposes the metrics-server pod to the network, which may be undesirable. We are working with the MicroK8s team to properly resolve this issue in MicroK8s directly.
As an optional step you can expand the More settings section to categorize the environment by adding it to a group or tagging it for better searchability.
Once you have entered your cluster configuration details, click Provision environment to begin the provision. Portainer will start provisioning your cluster with the options you selected. If you have other environments to configure click Next to proceed, otherwise click Close to return to the list of environments.
Provision progress
From the Environments page you will be able to see the progress of any running Kubernetes environment provisions. The status will be updated as the provision completes, and if the provision runs into problems an error will be displayed here. You can hover over the status or error for additional detail.
Once the provision completes, you will be able to access the environment as you would any other Portainer-configured environment.
Last updated