2024-10-20 09:31:03 +00:00
# K8S node
Installing a K8S node using [scripts from the k3s-host ](k3s-host ) directory.
## Imaging
2024-10-20 09:24:52 +00:00
Using installimage from the rescue instance.
- `wipefs -fa /dev/nvme*n1`
- `installimage -r no -n hetzner0?`
- Debian bookworm
- `PART / ext4 100G`
- `PART /srv ext4 all`
- ESC 0 + yes
- reboot
Partitioning.
- First disk
- OS
- non precious data such as the LXC containers with runners.
- Second disk
- a partition configured with DRBD
Debian user.
- `ssh root@hetzner0?.forgejo.org`
- `useradd --shell /bin/bash --create-home --groups sudo debian`
- `mkdir -p /home/debian/.ssh ; cp -a .ssh/authorized_keys /home/debian/.ssh ; chown -R debian /home/debian/.ssh`
- in `/etc/sudoers` edit `%sudo ALL=(ALL:ALL) NOPASSWD:ALL`
2024-10-20 09:31:03 +00:00
## Install helpers
2024-10-20 09:24:52 +00:00
Each node is identifed by the last digit of the hostname.
```sh
sudo apt-get install git etckeeper
git clone https://code.forgejo.org/infrastructure/documentation
cd documentation/k3s-host
cp variables.sh.example variables.sh
cp secrets.sh.example secrets.sh
```
Variables that must be set depending on the role of the node.
- first server node
- secrets.sh: node_drbd_shared_secret
- other server node
- secrets.sh: node_drbd_shared_secret
- secrets.sh: node_k8s_token: content of /var/lib/rancher/k3s/server/token on the first node
- variables.sh: node_k8s_existing: identifier of the first node (e.g. 5)
- etcd node
- secrets.sh: node_k8s_token: content of /var/lib/rancher/k3s/server/token on the first node
- variables.sh: node_k8s_existing: identifier of the first node (e.g. 5)
- variables.sh: node_k8s_etcd: identifier of the node whose role is just etcd (e.g. 3)
The other variables depend on the setup.
2024-10-20 09:31:03 +00:00
## Firewall
2024-10-20 09:24:52 +00:00
`./setup.sh setup_ufw`
2024-10-20 09:31:03 +00:00
## DRBD
2024-10-20 09:24:52 +00:00
DRBD is [configured ](https://linbit.com/drbd-user-guide/drbd-guide-9_0-en/#p-work ) with:
`./setup.sh setup_drbd`
Once two nodes have DRBD setup for the first time, it can be initialized by [pretending all is in sync ](https://linbit.com/drbd-user-guide/drbd-guide-9_0-en/#s-skip-initial-resync ) to save the initial bitmap sync since there is actually no data at all.
```sh
sudo drbdadm primary r1
sudo drbdadm new-current-uuid --clear-bitmap r1/0
sudo mount /precious
```
2024-10-20 09:31:03 +00:00
## NFS
2024-10-20 09:24:52 +00:00
`./setup.sh setup_nfs`
On the node that has the DRBD volume `/precious` mounted, set the IP of the NFS server to be used by k8s:
```sh
sudo ip addr add 10.53.101.100/24 dev enp5s0.4001
```
2024-10-20 09:31:03 +00:00
## K8S
2024-10-20 09:24:52 +00:00
For the first node `./setup.sh setup_k8s` . For nodes joining the cluster `./setup.sh setup_k8s 6` where `hetzner06` is an existing node.
- [metallb ](https://metallb.universe.tf ) instead of the default load balancer because it does not allow for a public IP different from the `k8s` node IP.
`./setup.sh setup_k8s_metallb`
2024-10-22 11:02:27 +00:00
- [traefik ](https://traefik.io/ ) [v2.10 ](https://doc.traefik.io/traefik/v3.1/ ) installed from the [v25.0 ](https://github.com/traefik/traefik-helm-chart/tree/v31.1.1 ) helm chart.
2024-10-20 09:24:52 +00:00
`./setup.sh setup_k8s_traefik`
- [cert-manager ](https://cert-manager.io/ ).
`./setup.sh setup_k8s_certmanager`
- NFS storage class
`./setup.sh setup_k8s_nfs`
2024-10-20 09:36:57 +00:00
## K8S NFS storage creation
2024-10-20 09:24:52 +00:00
Define the 20GB `forgejo-data` pvc owned by user id 1000.
```sh
./setup.sh setup_k8s_pvc forgejo-data 20Gi 1000
```