Skip to content
forked from vehagn/homelab

Configuration for my homelab running Talos Kubernetes provisioned with OpenTofu.

License

Notifications You must be signed in to change notification settings

evendark/homelab

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

🪨 Homelab 🏡

Repository for home infrastructure and Kubernetes cluster using GitOps practices.

Held together using Proxmox VE, OpenTofu, Talos, Kubernetes, Argo CD and copious amounts of YAML with some help from Renovate.


📖 Overview

This repository hosts the IaC (Infrastructure as Code) configuration for my homelab.

The Homelab is backed by Proxmox VE hypervisor nodes with VMs bootstrapped using OpenTofu/Terraform.

Most of the services run on Talos flavoured Kubernetes, though I'm also running a TrueNAS VM for storage and Home Assistant VM for home automation.

To organise all the configuration I've opted for an approach using Kustomized Helm with Argo CD which I've explained in more detail in this article.

I journal my homelab journey over at my self-hosted blog.

🧑‍💻 Getting Started

If you're new to Kubernetes I've written a fairly thorough guide on Bootstrapping k3s with Cilium. In the article I try to guide you from a fresh Debian 12 Bookworm install to a working cluster using the k3s flavour of Kubernetes with Cilium as a CNI and IngressController.

I've also written an article on how to get started with Kubernetes on Proxmox if virtualisation is more your thing.

I'm currently working on an article on how to bootstrap your own Talos-cluster using this repo.

⚙️ Core Components

  • Proxmox VE: Server management and KVM hypervisor.
  • OpenTofu: Open source infrastructure as code tool.
  • Cilium: eBPF-based Networking, Observability, Security.
  • Argo CD: Declarative, GitOps continuous delivery tool for Kubernetes.
  • Cert-manager: Cloud native certificate management.
  • Sealed-secrets: Encrypt your Secret into a SealedSecret, which is safe to store - even inside a public repository.

🗃️ Folder Structure

.
├── 📂 docs                # Documentation
├── 📂 k8s                 # Kubernetes manifests
│   ├── 📂 apps            # Applications on
│   ├── 📂 infra           # Infrastructure components
│   └── 📂 sets            # Bootstrapping ApplicationSets
└── 📂 tofu                # Tofu configuration
    ├── 📂 home-assistant  # Home Assistant VM
    └── 📂 kubernetes      # Kubernetes VM configuration
        ├── 📂 bootstrap   # Kubernetes bootstrap config
        └── 📂 talos       # Talos configuration 

🖥️ Hardware

Name Device CPU RAM Storage Purpose
Abel CWWK 6 LAN Port Intel i3-N305 32 GB DDR5 - Control-plane
Euclid ASUS ExpertCenter PN42 Intel N100 32 GB DDR4 - Control-plane
Cantor ASUS PRIME N100I-D D4 Intel N100 32 GB DDR4 5x8TB HDD RaidZ2 NAS/Control-plane
Gauss Dell Precision Tower 5810 Xeon E5-1650 v3 64 GB DDR4 ECC 14 TB HDD Compute

🏗️ Work in Progress

  • Renovate for automatic updates
  • Keycloak for auth
  • Implement NetBird
  • AdGuard Home
  • External DNS
  • Clean up DNS config

👷‍ Future Projects

  • OPNSense/pfSense
  • Use BGP instead of ARP
  • Dynamic Resource Allocation for GPU
  • Local LLM
  • Cilium mTLS & SPIFFE/SPIRE

About

Configuration for my homelab running Talos Kubernetes provisioned with OpenTofu.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HCL 100.0%