Modern self-hosting framework, fully automated from empty disk to operating services with a single command.
Go to file
2021-06-06 13:57:38 +07:00
apps Add Wireguard access server 2021-05-23 14:03:07 +07:00
docs Remove LXC debugging 2021-06-05 11:26:10 +07:00
infra Improve makefile targets consistency 2021-05-23 12:24:32 +07:00
metal Add handler to stop PXE server after completed 2021-06-06 13:49:54 +07:00
scripts Initial scripts 2021-05-02 22:25:38 +07:00
tools Add git back to the tools container 2021-05-23 02:57:09 +07:00
.gitattributes Add git attributes 2021-05-16 14:55:08 +07:00
.gitignore Move RKE cluster to sperate module, with cleaner Ansible check 2021-05-02 23:07:16 +07:00
LICENSE
Makefile Improve makefile targets consistency 2021-05-23 12:24:32 +07:00
README.md Add hardware model number 2021-06-06 13:57:38 +07:00

Homelab

⚠️ WORK IN PROGRESS

Hardware

Hardware

  • 4 nodes of NEC SFF PC PC-MK26ECZDR (Japanese version of the ThinkCentre M700)
    • CPU: Intel Core i5-6600T
    • RAM: 16GB
    • SSD: 128GB
  • TP-Link TL-SG108 switch

Technology stack


Ansible

Cloudflare

Docker

Fedora

Gitea

Helm

Kubernetes

Prometheus

Rancher

Terraform

Vault

Wireguard

Architecture

Quick explanation

Layers

Layer Name Description Provisioner
0 metal Bare metal OS installation, Terraform state backend,... Ansible, PXE server
1 infra Kubernetes clusters Terraform, Helm
2 apps Gitea, Vault and more in the future Argo

Usage

Prerequisite

For the controller (to run Ansible, stateless PXE server, Terraform...):

  • SSH keys in ~/.ssh/{id_ed25519,id_ed25519.pub} (you can generate it with ssh-keygen -t ed25519)
  • Docker with host networking driver (which means only Docker on Linux hosts, you can use a Linux virtual machine with bridged networking if you're on macOS or Windows)

For bare metal nodes:

  • PXE IPv4 enabled
  • Wake-on-LAN enabled
  • Secure boot disabled (optional, depending on the OS)

Configurations

Building

Open the tools container:

make tools

Then build the homelab:

make