/homelab

Kubernetes local cluster using Raspberry PIs 5

Primary LanguageShell

Homelab

Homelab with Kubernetes using Raspberry PIs 5

Stack

  • 3 Raspberry PIs 5
  • Debian Bookworm
  • Ansible
  • containerd
  • Kubernetes

Giving a user access to the cluster

Create a private key

openssl genrsa -out username.key 2048

Create a CSR

openssl req -new -key username.key -out username.csr -subj "/CN=username"

Create a CertificateSigningRequest k8s object

Encode the username csr

export csr=$(cat username.csr | base64 | tr -d '\n')

Create a new file with the following yaml and save to username-csr.yaml

apiVersion: certificates.k8s.io/v1
kind: CertificateSigningRequest
metadata:
  name: username
spec:
  request: <base64-csr-here>
  signerName: kubernetes.io/kube-apiserver-client
  usages:
  - digital signature
  - key encipherment
  - client auth

Place the encoded csr in the CRT request

sed -i "s|\(request: \).*|\1$csr|" username-csr.yaml

Approve the csr and get the certificate

kubectl certificate approve username
kubectl get csr cflor -ojsonpath='{.status.certificate}'

Configure kube config with the ca, crt and the private key

Example of kube config

apiVersion: v1
clusters:
- cluster:
    certificate-authority: /home/cflor/.homelab/ca.crt
    server: https://192.168.1.9:8080
  name: home
contexts:
- context:
    cluster: home
    namespace: default
    user: cflor
  name: home
current-context: home
kind: Config
preferences: {}
users:
- name: cflor
  user:
    client-certificate: /home/cflor/.homelab/cflor.crt
    client-key: /home/cflor/.homelab/cflor.key

Create a clusterrole binding to give the user access to the desired resources

Example of a cluster role binding with cluster admin permission

apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
  name: cflor
  resourceVersion: "3944821"
roleRef:
  apiGroup: rbac.authorization.k8s.io
  kind: ClusterRole
  name: cluster-admin
subjects:
- apiGroup: rbac.authorization.k8s.io
  kind: User
  name: cflor

In this case the user is cflor

Configure kubelet to use certificates served by certificates.k8s.io

By default kubelet use self-signed certificates generated by kubeadm, we can configure kubelet to use certificates generated by certificates.k8s.io. external service like metrics-server can't be secured with kubelet through TLS.

Edit kubelet-config configmap and add serverTLSBootstrap: true.

Edit kubelet config to each node and restart kubelet service

ansible all -b -i inventory.yaml -a "echo 'serverTLSBootstrap: true' >> /var/lib/kubelet/config.yaml" -m shell
ansible all -b -i inventory.yaml -a "sudo systemctl restart kubelet" -m shell

TODO

  • Verify the admin.conf kubeconfig to understand - DONE
  • Sign a certificate to use from the personal laptop - DONE
  • Configure the other instances to join the cluster - DONE
  • Deploy ArgoCD on it - DONE
  • Deploy jackett
  • Start working in the personal blogi
  • Configure Samba in k8s with PV/PVC
  • Refactor the changed_when to when and use changed_when whenever necessary
  • Test how to ensure a pod will restart when a node get an unexpected shutdown

Ideas to host in the cluster

  • Jackett
  • Personal blog
  • Plex server / DNLA
  • Cripto Miner