P2P support
Note
This feature is crazy and experimental! Do not run in production servers. Feedback and bug reports are welcome, as we are improving the p2p aspects of Kairos.Deploying Kubernetes at the Edge can be a complex and time-consuming process, especially when it comes to setting up and managing multiple clusters. To make this process easier, Kairos leverages peer-to-peer technology to automatically coordinate and create Kubernetes clusters without the need of a control management interface.
With this feature, users don’t need to specify any network settings. They can just set the desired number of master nodes (in the case of an HA cluster) and the necessary configuration details, and Kairos will take care of the rest. The peer-to-peer technology allows the nodes in the cluster to communicate and coordinate with each other, ensuring that the clusters are set up correctly and efficiently with K3s.
This makes it easier to deploy and manage Kubernetes clusters at the Edge, saving user’s time and effort, allowing them to focus on running and scaling their applications. For more information about how does it work behind the scenes, check out the architecture section.
You can find full examples in our examples section:
- Full end to end example to bootstrap a self-coordinated cluster with Kairos and AuroraBoot
- Self-coordinated K3s HA cluster with KubeVIP
- Multi-node, single master setup
- Multi-node, HA setup
- Single-node setup
This feature is currently experimental and can be optionally enabled by adding the following configuration to the node deployment file. If you are not familiar with the installation process, it is suggested to follow the quickstart:
p2p:
 # Disabling DHT makes co-ordination to discover nodes only in the local network
 disable_dht: true #Enabled by default
 # Automatic cluster deployment configuration
 auto:
   ha:
     # Enables HA control-plane
     enable: true
     # number of HA master node (beside the one used for init) for the control-plane
     master_nodes: 2
 # network_token is the shared secret used by the nodes to co-ordinate with p2p.
 # Setting a network token implies auto.enable = true.
 # To disable, just set auto.enable = false
 network_token: "YOUR_TOKEN_GOES_HERE"
The token p2p.network_token is a base64 encoded string which
contains an edgevpn token.
To enable the automatic cluster deployment with peer-to-peer technology, specify a p2p.network_token. To enable HA, set p2p.auto.ha.master_nodes to the number of wanted HA/master nodes. Additionally, the p2p block can be used to configure the VPN and other settings as needed.
With these settings used to deploy all the nodes, those will automatically communicate and coordinate with each other to deploy and manage the Kubernetes cluster without the need for a control management interface and user intervention.
Configuration
A minimum configuration file, that bootstraps a cluster with a simple single-master topology, can look like the following:
#cloud-config
hostname: "kubevip-{{ trunc 4 .MachineID }}"
users:
- name: "kairos"
  passwd: "kairos"
  ssh_authorized_keys:
  - github:mudler
p2p:
 network_token: "YOUR_TOKEN_GOES_HERE"
The p2p block is used to configure settings related to the mesh functionalities. The minimum required argument is the network_token and there is no need to configure k3s manually with the k3s block as it is already implied.
Note
Thek3s block can still be used to override other k3s settings, e.g. args.The network token is a shared secret available to all the nodes of the cluster. It allows the node to co-ordinate and automatically assign roles. To generate a network token, see documentation.
Simply applying the same configuration file to all the nodes should eventually bring one master and all the other nodes as workers. Adding nodes can be done also in a later step, which will automatically setup the node without any further configuration.
Full example:
#cloud-config
install:
  auto: true
  device: "auto"
  reboot: true
hostname: "kubevip-{{ trunc 4 .MachineID }}"
users:
- name: "kairos"
  passwd: "kairos"
  ssh_authorized_keys:
  - github:mudler
## Sets the Elastic IP used in KubeVIP
kubevip:
  eip: "192.168.1.110"
  # Specify a manifest URL for KubeVIP. Empty uses default
  manifest_url: ""
  # Enables KubeVIP
  enable: true
  # Specifies a KubeVIP Interface
  interface: "ens18"
p2p:
 role: "" # Set an hardcoded role, optional
  # Disabling DHT makes co-ordination to discover nodes only in the local network
 disable_dht: true #Enabled by default
 # Configures a VPN for the cluster nodes
 vpn:
   create: false # defaults to true
   use: false # defaults to true
   env:
      .....
 # Automatic cluster deployment configuration
 auto:
   # Enables Automatic node configuration (self-coordination)
   # for role assignment
   enable: true
   # HA enables automatic HA roles assignment.
   # A master cluster init is always required,
   # Any additional master_node is configured as part of the 
   # HA control plane.
   # If auto is disabled, HA has no effect.
   ha:
     # Enables HA control-plane
     enable: true
     # Number of HA additional master nodes.
     # A master node is always required for creating the cluster and is implied.
     # The setting below adds 2 additional master nodes, for a total of 3.
     master_nodes: 2
     # Use an External database for the HA control plane
     external_db: "external-db-string"
 # network_token is the shared secret used by the nodes to co-ordinate with p2p
 network_token: "YOUR_TOKEN_GOES_HERE"
In the YAML configuration example, there are several important keywords that control the behavior of the automatic cluster deployment:
| Keyword | Description | 
|---|---|
| p2p | Configures the peer to peer networking of the cluster | 
| p2p.disable_dht | Disables the distributed hash table for cluster discovery | 
| p2p.network_token | The shared secret used by the nodes to coordinate with p2p | 
| p2p.network_id | Optional, unique identifier for the kubernetes cluster. It allows bootstrapping of multiple cluster using the same network token | 
| p2p.role | Force a specific role for the node of the cluster | 
| p2p.vpn | Configures a VPN for the cluster nodes | 
| p2p.vpn.create | Enables the creation of the VPN | 
| p2p.vpn.use | Enables the use of the VPN for routing Kubernetes traffic of the cluster | 
| p2p.vpn.env | Configures the environment variables used to start for the VPN | 
| p2p.vpn.auto | Configures the automatic deployment of the cluster | 
| p2p.auto.enable | Enables automatic node configuration for role assignment | 
| p2p.auto.ha | Configures the high availability settings for the cluster | 
| p2p.auto.ha.enable | Enables the high availability settings | 
| p2p.auto.ha.master_nodes | The number of additional HA master nodes expected in the cluster. | 
| p2p.auto.ha.external_db | The external database used for high availability | 
Elastic IP
If deploying a cluster in a Local network, it might be preferable to disable the VPN functionalities.
We use KubeVIP to provide an elastic ip for the control plane that can be configured via a specific block:
p2p:
 network_token: ".."
 vpn:
   # Disable VPN, so traffic is not configured with a VPN
   create: false
   use: false
## Sets the Elastic IP used in KubeVIP
kubevip:
  eip: "192.168.1.110"
  # Specify a manifest URL for KubeVIP. Empty uses default
  manifest_url: ""
  # Enables KubeVIP
  enable: true
  # Specifies a KubeVIP Interface
  interface: "ens18"
| Keyword | Description | 
|---|---|
| kubevip | Block to configure KubeVIP for the cluster | 
| kubevip.eip | The Elastic IP used for KubeVIP. Specifying one automatically enables KubeVIP. Choose a free IP that is not in a DHCP range of your network. | 
| kubevip.manifest_url | The URL for the KubeVIP manifest | 
| kubevip.enable | Enables KubeVIP for the cluster | 
| kubevip.interface | The interface used for KubeVIP | 
A full example, with KubeVIP and HA:
#cloud-config
install:
  auto: true
  device: "auto"
  reboot: true
hostname: "kubevip-{{ trunc 4 .MachineID }}"
users:
- name: "kairos"
  passwd: "kairos"
  ssh_authorized_keys:
  - github:mudler
p2p:
 network_token: "..."
 ha:
   master_nodes: 2
 vpn:
   # Disable VPN, so traffic is not configured with a VPN
   create: false
   use: false
kubevip:
  eip: "192.168.1.110"
network_token
The network_token is a unique code that is shared among nodes and can be created with the Kairos CLI or edgevpn. This allows nodes to automatically connect to the same network and generates private/public key pairs for secure communication using end-to-end encryption.
To generate a new token, run:
docker run -ti --rm quay.io/mudler/edgevpn -b -g
kairos generate-token
Join new nodes
To add new nodes to the network, follow the same process as before and use the same configuration file for all machines. Unless you have specified roles for each node, no further changes to the configuration are necessary. The machines will automatically connect to each other, whether they are on a local or remote network.
Connect to the nodes
To connect to the nodes, you can use kairosctl and provide the network_token to establish a tunnel to the nodes network.
sudo kairosctl bridge --network-token <TOKEN>
This command creates a TUN device on your machine and allows you to communicate with each node in the cluster.
Note
The command requires root permissions in order to create a TUN/TAP device on the host.An API will be also available at localhost:8080 for inspecting the network status.
Get kubeconfig
To get the cluster kubeconfig, you can log in to the master node and retrieve it from the engine (e.g., it is located at /etc/rancher/k3s/k3s.yaml for K3s) or use the Kairos CLI. If using the CLI, you must be connected to the bridge or logged in from one of the nodes and run the following command in the console:
kairosctl get-kubeconfig > kubeconfig
Note
Note that you must run kairos bridge in a separate window as act likekubectl proxy and access the Kubernetes cluster VPN. Keep the kairos bridge command running to operate the cluster.