We use cookies to make your experience better.
Set up K3s on an Ubuntu machine to deploy Coder.
This article will show you how to install K3s onto a new Ubuntu 20.04 LTS machine for use with Coder.
K3s is a lightweight Kubernetes distribution that works well for single-node or multi-node clusters. For single-user trial purposes, you may want to consider the options in local preview.
This installation method is not officially supported or tested by Coder. If you have questions or run into issues, feel free to reach out using our community Slack channel.
We do not recommend using K3s for production deployments of Coder.
Before proceeding, please make sure that:
You have an Ubuntu 20.04 machine: This can be a bare metal or a virtual machine.
Ensure that the machine's specs satisfy Coder's resource requirements, since your experience with Coder is dependent on your system specs.
You have the following software installed on your machine:
Your network policy or firewall accepts incoming traffic on:
The following steps are based on Calico's quickstart guide for setting up K3s. However, you will disable K3s' default network policies and Traefik in favor of Calico and nginx-ingress.
Create a single-node K3s cluster:
curl -sfL https://get.k3s.io | K3S_KUBECONFIG_MODE="644" INSTALL_K3S_EXEC="--flannel-backend=none --cluster-cidr=192.168.0.0/16 --disable-network-policy --disable=traefik" sh -
Per the Calico docs:
If
192.168.0.0/16
is already in use within your network, you must select a different pod network CIDR by replacing192.168.0.0/16
in the above command.K3s installer generates kubeconfig file in
/etc
with limited permissions; by using theK3S_KUBECONFIG_MODE
environment, you are assigning the necessary permissions to the file and making it accessible for other users.
Install the Calico operator and CRDs (Calico implements Kubernetes pod networking and policy enforcement):
kubectl create -f https://docs.projectcalico.org/manifests/tigera-operator.yaml
kubectl create -f https://docs.projectcalico.org/manifests/custom-resources.yaml
Confirm that all of the pods are running:
watch kubectl get pods --all-namespaces
Modify Calico to enable IP forwarding, which is needed for container networking.
vim /etc/cni/net.d/10-calico.conflist
kubectl edit cm cni-config -n calico-system
Under container_settings
, set allow_ip_forwarding
to true
:
"container_settings": {
"allow_ip_forwarding": true
}
Occasionally, Helm will not recognize the K3s cluster (see k3s-io/k3s#1126 for more information).
If this happens, but you want to interface with the cluster from your local
machine, copy /etc/rancher/k3s/k3s.yaml
to ~/.kube/config
.
After copying this file from the K3s node to your local workstation:
localhost
or 127.0.0.1
with the host's public IP
address in the copied file443
# on the host machine:
cp /etc/rancher/k3s/k3s.yaml ~/.kube/config
If you have already installed Coder or are using our hosted beta, you can add this cluster as a workspace provider.
To access Coder through a secure domain, review our guides on configuring and using TLS certificates.
Once complete, see our page on installation.
See an opportunity to improve our docs? Make an edit.