Hi. This info has been gathered from multiple sources that I used to get a working, multi-node k3s cluster installed in my own lab environment (see sources section at the end of this document).
IMO, a good way to approach using these scripts is to open a text editor and edit k3sup-install.sh
and k3sup-cluster-deploy.sh
side-by-side with this document.
This is especially true with k3sup-cluster-deploy.sh
, as you will need to modify at least one of the variables near the top of the script for your specific environment.
-
Installing the
k3sup
remote installation program:- First, run
sudo ./k3sup-install.sh
to install k3sup locally (make sure to use sudo, or elsek3sup
may not be properly copied to /usr/local/bin)
- First, run
-
Pre-install Notes for preparing Raspberry Pi nodes, using Raspian:
-
Usually the pi user has passwordless sudo access - if not, go ahead and enable that
- (you can disable it again after we've install our nodes, if you want to).
-
Check the link below, from rancher.com regarding Raspbian Buster, and iptables. You may need to run a few commands to modify iptables on your Pi.
-
Make sure the following values are set in /boot/cmdline.txt:
cgroup_enable=cpuset cgroup_enable=memory cgroup_memory=1
- Reboot the pi if you have to add the above change.
-
-
Using
k3s-cluster-deploy.sh
to install k3s on multiple nodes-
Open up
k3s-cluster-deploy.sh
in your text editor, and look at the comment for the following variables, near the top:remote_hosts
(this is a list of all the IP addresses you would like k3s installed on)MAIN_NODE
(this is the IP address of the node which will be the main/master node)REMOTE_USER
(this is the user which will be used to install k3s on each remote host
-
You will need ssh access to each IP address in
remote_hosts
asREMOTE_USER
from the machine where you are performing this installation.- IMPORTANT:
k3s-cluster-deploy.sh
will attempt to create/copy a new ecdsa ssh key to be used during the installation process- This is because
k3sup
seems to not like rsa keys, and the installation may fail if rsa keys are used for withk3sup
during install.
- This is because
- IMPORTANT:
-
Once you have examined/modified
k3s-cluster-deploy.sh
to suite your site install needs, go ahead and run it in echo mode (e.g. make sure the lineecho=echo
at the top of the script is NOT commented out).- This should produce the list of commands that will be executed by
k3s-cluster-deploy.sh
- This should produce the list of commands that will be executed by
-
If there are errors regarding an existing
~/.kube
or~/.kube/config
or$KUBECONFIG
- please modify your local environment accordingly (e.gunset KUBECONFIG
andmv ~/.kube ~/dot.kube
for this install) -
If there are no errors, and everything looks in order, comment out the echo=echo line near the top of
k3s-cluster-deploy.sh
and run again.
-
-
Checking on your cluster
-
If everything went well, you should be able to run the following commands to get a view of your cluster status:
-
export KUBECONFIG=~/.kube/config
-
kubectl -n kube-system get all
-
kubectl get nodes -o wide
-
-
You may want to set KUBECONFIG in your environment for future sessions too.
-
If you are planning on installing additional nodes at a later date, take note of the k3s version, which should be shown by the
kubectl get nodes
command.- If a new version is released between the original install and the installation of additional nodes, version incompatibilities can cause problems - so it's best to install the same version as the main/master node.
- Look at the comments for
K3S_VERSION
in the scriptk3s-cluster-deploy.sh
for details and limitations.
-
-
Testing these scripts
- In order to test these scripts in multiple scenarios, I did the following before each run:
- On the installation machine, where I'm running the install from:
rm -rf ~/.kube/
unset KUBECONFIG
- On each worker node, ssh in and run:
/usr/local/bin/k3s-killall.sh
/usr/local/bin/k3s-agent-uninstall.sh
sudo rm -rf /etc/rancher
- On the main/master node, ssh in and run:
/usr/local/bin/k3s-killall.sh
/usr/local/bin/k3s-uninstall.sh
sudo rm -rf /etc/rancher
- On the installation machine, where I'm running the install from:
- In order to test these scripts in multiple scenarios, I did the following before each run:
-
Sources