June 27th, 2024

My First Kubernetes: k3s 'cluster' on 3 Orange Pi Zero 3's

Setting up a Kubernetes cluster with Orange Pi Zero 3 boards involves control and worker nodes, deploying apps, and overcoming ARM64 image compatibility challenges. Detailed steps, including Dashboard setup and user management, are shared, offering practical insights for Kubernetes enthusiasts.

Read original articleLink Icon
My First Kubernetes: k3s 'cluster' on 3 Orange Pi Zero 3's

In this article, the author describes setting up a Kubernetes cluster using three Orange Pi Zero 3 single-board computers. The cluster includes a control plane node and worker nodes, with detailed instructions on installation and configuration using k3s. The setup involves deploying the Kubernetes Dashboard, a Hello World app, and testing failover mechanisms. The author also shares challenges faced during deployment, such as compatibility issues with ARM64 images. The article provides step-by-step guidance on setting up the cluster, managing nodes, and installing the Dashboard UI using Helm. Additionally, it covers creating user credentials, testing deployments, and accessing the Kubernetes Dashboard. The author emphasizes using declarative YAML files for configurations and shares personal experiences and learnings throughout the setup process. The article serves as a practical guide for individuals looking to explore Kubernetes on small-scale hardware like the Orange Pi Zero 3.

Link Icon 11 comments
By @alias_neo - 7 months
I did something similar a few years back and wrote a blog series about it[0].

Ultimately, I ripped it apart and stuck to using my x86 servers and now run Talos Linux[1] which is currently my favourite way to do Kubernetes on bare metal.

With Pi4, the cluster services just used too much of the available compute and though it was a fun project, want practical for my home lab.

Now the Pi5 is available (and I have some), I might look at adding them to my existing clusters for some mixed-architecture fun.

[0]https://2byt.es/post/bantamcloud/01-build/ [1] https://www.talos.dev/

By @birdiesanders - 7 months
The k8s hater squad loves to neglect the fact that k8s can be, just like Linux, fun. The complexity is endearing in a special way. Kubernetes is Linux underneath, and learning how that manifests is a lovely journey to go on.
By @udev4096 - 7 months
k3s is a perfect choice for a home lab. The setup is extremely simple and it removes a lot of bloat ware that comes with k8s (for instance, different storage plugins for cloud providers)
By @hi_hi - 7 months
What is the trait in certain people (most here I would guess) that makes these kinds of projects....fun. No, not fun, thats not the right word. Necessary? Appealing? Rewarding?

I went through my own journey to get an understanding with k8s, in a homelab setting. It started with MicroK8s on a VM running on a 2011 macbook pro I had lying around. That was painful, but I eventually had something useful running, until it weirdly self combusted one day and weeks of hard work resulted in ssh failing to connect because the K8s instance seemed to have deleted itself from the VM. I think it was trying to tell me something.

I decided to persist, but this time with k3s, and no VM on an outdated Mac. Instead I went with an outdated HP Thinclient. A bargain on ebay, with extra RAM. That worked much better. Now I have a bunch of great self hosted software for home media, development servers, git repos, docker servers, CI/CD pipelines. With storage managed by a NAS. All managed via simple helm charts. It's really useful. I discovered Tailscale along the way, that opened up a whole new world of self hosting abilities.

I get the nerd sniping, I've seen k8s abused in work situations too, but underneath it, people just wanted to learn.

I had a similar situation recently trying to bake shokupan for the first time. There was a new bread maker. It made perfect rising normal bread. But trying the Shokupan recipe produced a damp brick. A total failure. I persisted, read a ton of recipes and blogs, watched countless youtube videos. I was convinced it was an equipment or method issue. Eventually, 3 damp bricks later, I realised the yeast was out of date. This was the first thing people recommended to check, but I thought I knew better because "it worked on my machine" with the normal bread. Anyway, the 4th attempt with new yeast produced a perfect loaf. And I learnt a ton of other useful info for baking great bread along the way. The elation when it finally worked, and I had amazing fluffy home made bread, was a very similar sense of reward and accomplishment to finally getting some program or system to work.

By @globular-toast - 7 months
Is there much to be gained by using physical hardware like this as opposed to a bunch of VMs? I get that plugging in cables and flashing lights is fun and stuff, but let's say you already have a homelab and are over that. Are there lessons about k8s you can only learn on "real" hardware and not VMs?

I thought about this a while back when there was a global shortage of Raspberry Pis. I'd see people with like 8 of them in a toy cluster and thought it was a shame because some people might have a real use for one but couldn't get one.

You can use things like docker-machine or Vagrant to easily spin up a bunch of VMs for things like this. Also you can use Rancher to automatically provision a cluster for you (but I guess you won't learn as much that way).

By @basemi - 7 months
For those interested with the storage details:

> I run the Orange Pi Boards without a Micro SD Card, they boot up via PXE with an NFS root file system, so I cannot use overlayfs2. Therefore during installation I provide an extra parameter to use the native shapshotter. Also some etcd timeouts are raised.

By @ofrzeta - 7 months
It's funny that so many people feel the need of running a virtualization technology like Kubernetes on bare metal. I did it myself with a Raspi cluster but in retrospect you are wasting a lot of time with little return while there are great solutions like microk8s or kind available that can be set up in minutes. Anyway, have fun, if you think it's worth it :)
By @hardwaresofton - 7 months
Does anyone know of whether k8s is making inroads in "edge"/low resource compute environments? It seems like despite the work of companies like k3s people still think of k8s as too "heavy weight" for the "edge".
By @rcarmo - 7 months
I think this is a sort of rite of passage. I just realized that https://github.com/rcarmo/raspi-cluster is TEN YEARS OLD now…
By @shakiXBT - 7 months
I've been using k3s in prod for over 3 years now.

Both single-node (yeah, sue me) and multi-node have been working great, required minimal maintenance and have a super straight forward install procedure