Homelab
Proxmox LXC Docker Ansible Linux Debian Alpine Bash NGINX Caddy WireGuard OPNsense

My homelab started as an old repurposed desktop and has grown into a proper self-hosted infrastructure stack running on Proxmox, with services organized into LXCs. I even picked up a kitted-out PowerEdge along the way — though given the electricity bill, it mostly sleeps until I need it for backups.

The core of it is built around services I actually rely on day-to-day: Pi-hole for DNS, WireGuard for remote access, Gitea for storing configs and projects, NGINX as a central reverse proxy, and Certbot handling certificate renewal and distribution to the hosts that need them. On top of that sits monitoring with Grafana and Prometheus, Home Assistant for home automation, and a handful of other self-hosted applications. Networking is handled with OPNsense, with VLANs segmenting IoT and management traffic, and DDNS via ddclient to handle IP rotation.

It’s a joint project with my brother, and that’s where things got interesting. Early on we were essentially pasting the commands we ran as documentation — it was impossible to keep up to date. As the setup grew more complex, we realized we needed the actual state of the lab to be the source of truth, not a markdown file someone forgot to update. That pushed us toward Ansible, and writing proper IaC forced a level of discipline that made everything more maintainable and reproducible.

Running this long-term has taught me a lot about how production infrastructure actually holds together — designing systems that interoperate reliably, keeping things documented in a way that survives time and a second person, and debugging the inevitable moments when something upstream breaks something downstream.

My ansible roles and collections can be found here.

Project Details

My homelab is where I tinker and learn new technologies.