How to use the default Network

Canonical Kubernetes includes a high-performance, advanced network plugin called Cilium. The network component allows cluster administrators to leverage software-defined networking to automatically scale and secure network policies across their cluster.

Prerequisites

This guide assumes the following:

  • You have root or sudo access to the machine.

  • You have a bootstrapped Canonical Kubernetes cluster (see the Getting Started guide).

Check Network status

Find out whether Network is enabled or disabled with the following command:

sudo k8s status

The default state for the cluster is network disabled.

Enable Network

To enable Network, run:

sudo k8s enable network

For more information on the command, execute:

sudo k8s enable --help

Configure Network

It is not possible to reconfigure the network on a running cluster as this will lead to unreachable pods/services and nodes. Any configuration options the CNI needs to be aware of (e.g. pod and service CIDR, IPv6 support) are set during the cluster bootstrap (k8s bootstrap command).

Check Network details

Let’s look at the detailed status of the network as reported by Cilium.

First, find the name of the Cilium pod:

sudo k8s kubectl get pod -n kube-system -l k8s-app=cilium

Once you have the name of the pod, run the following command to see Cilium’s status:

sudo k8s kubectl exec -it cilium-97vcw -n kube-system -c cilium-agent \
  -- cilium status

You should see a wide range of metrics and configuration values for your cluster.

Disable Network

You can disable the built-in network:

Warning

If you have an active cluster, disabling Network may impact external access to services within your cluster. Ensure that you have alternative configurations in place before disabling Network.

If your underlying network is Cilium you will have to run sudo k8s disable gateway before disabling network.

sudo k8s disable network

For more information on this command, run:

sudo k8s disable --help