Welcome to the repository for my personal homelab infrastructure. This monorepo contains all the code and configurations for managing my homelab, including various services and tools. This repository will probably never be finished, as I'll always be adding new services or tools to my homelab, where I'd like to make improvements on them.
Warning
This repository is a work in progress and currently in a proof of concept phase to find the way I want to manage this homelab. It is not yet ready to be reused or forked.
Note
This repository has been designed to be used inside a DevContainer, so any other way to interact with it will not be documented.
# Clone the repository
git clone https://github.com/chezmoi-sh/atlas.git
# Run the development environment
devcontainer up --workspace-folder .
devcontainer exec --workspace-folder . -- zsh
├── .devcontainer # Development environment setup (DevContainer/Codespaces)
│ ├── devcontainer.json # DevContainer configuration file
│ └── Dockerfile # Dockerfile on which the DevContainer is based
├── .github
│ └── assets # Repository assets (images, video, etc.) used in the documentation.
├── projects
│ └── nex.rpi # Mission-critical applications for the homelab (NEXus · Raspberry PI)
├── scripts
│ └── folderinfo # Perl script to generate a tree-like structure of directories
├── .lefthook.yaml # Git hooks configuration file (using lefthook)
└── .mise.toml # Environment (vars, tools and tasks) definition file (using mise-en-place)
Note
I'm currently trying to find a way to manage my homelab infrastructure as code. This roadmap is a work in progress and will be updated as I find new ways to improve my homelab. All the history of my choices and changes will be documented in the CHANGELOG.
-
Try usingdocker-compose
and scripts to manage all containers in the homelab (See CHANGELOG) -
Try usingPulumi
to manage the infrastructure (See CHANGELOG) - Try using
Helm
to manage the Kubernetes applications andTerraform
to manage the infrastructure (See CHANGELOG)
This repository is licensed under the Apache-2.0.
Caution
This is a personal project intended for my own use. Feel free to explore and use the code, but please note that it comes with no warranties or guarantees. Use it at your own risk.