Major documentation updates reflecting current deployment state: README.md: ✅ Updated features list with automated setup capabilities ✅ Accurate deployment workflow (12 containers, 7 additional stacks) ✅ Corrected setup script description (automated Authelia secrets) ✅ Removed manual secret generation steps ✅ Added note about optional image pre-pull ✅ Clarified .env requirements (Authelia secrets now automated) docs/getting-started.md: ✅ Streamlined quick setup workflow (removed manual secrets) ✅ Comprehensive setup script capabilities list ✅ Detailed deployment script behavior ✅ Added interactive Authelia configuration details ✅ Clarified argon2id password hash generation process ✅ Updated login credentials location ✅ Removed outdated .env location warnings docs/quick-reference.md: ✅ Added deployment scripts reference section ✅ Complete setup-homelab.sh documentation ✅ Complete deploy-homelab.sh documentation ✅ Added reset-test-environment.sh with warnings ✅ Updated stack overview with container counts ✅ Clarified which stacks deploy by default vs available in Dockge ✅ Noted Watchtower temporary disable status docs/troubleshooting/COMMON-ISSUES.md (NEW): ✅ Installation issues (Docker permissions, timeouts, port conflicts) ✅ Deployment issues (Authelia loops, Watchtower status, Homepage URLs) ✅ Service-specific issues (Gluetun, Pi-hole, Dockge) ✅ Performance troubleshooting ✅ Reset and recovery procedures with warnings ✅ Complete getting help section with commands Total changes: 456 additions, 71 modifications across 4 files Documentation now accurately reflects Round 9 deployment capabilities
306 lines
9.9 KiB
Markdown
306 lines
9.9 KiB
Markdown
# Getting Started Guide
|
|
|
|
Welcome to your AI-powered homelab! This guide will walk you through setting up your production-ready infrastructure with Dockge, Traefik, Authelia, and 40+ services.
|
|
|
|
## Quick Setup (Recommended)
|
|
|
|
For most users, the automated setup script handles everything:
|
|
|
|
### Prerequisites
|
|
- **Fresh Debian/Ubuntu server** (or existing system)
|
|
- **Root/sudo access**
|
|
- **Internet connection**
|
|
- **VS Code with GitHub Copilot** (for AI assistance)
|
|
|
|
### Simple Setup
|
|
|
|
1. **Connect to your server** via SSH
|
|
2. **Install git if needed**
|
|
```bash
|
|
sudo apt update && sudo apt upgrade -y && sudo apt install git
|
|
|
|
3. **Clone the rep**:
|
|
```bash
|
|
git clone https://github.com/kelinfoxy/AI-Homelab.git
|
|
cd AI-Homelab
|
|
|
|
4. **Configure environment**:
|
|
```bash
|
|
cp .env.example .env
|
|
nano .env # Edit with your domain and tokens
|
|
```
|
|
|
|
**Required variables in .env:**
|
|
- `DOMAIN` - Your DuckDNS domain (e.g., yourdomain.duckdns.org)
|
|
- `DUCKDNS_TOKEN` - Your DuckDNS token from [duckdns.org](https://www.duckdns.org/)
|
|
- `ACME_EMAIL` - Your email for Let's Encrypt certificates
|
|
- `SURFSHARK_USERNAME` and `SURFSHARK_PASSWORD` - If using VPN
|
|
|
|
**Note:** The `.env` file stays in the repository folder (`~/AI-Homelab/.env`). The deploy script copies it to stack directories automatically. Authelia secrets are generated by the setup script.
|
|
|
|
5. **Run the setup script:**
|
|
```bash
|
|
sudo ./scripts/setup-homelab.sh
|
|
```
|
|
|
|
The script will:
|
|
- Update system packages
|
|
- Install Docker Engine + Compose V2 (if needed)
|
|
- Configure user groups (docker, sudo)
|
|
- Set up firewall (UFW)
|
|
- Enable SSH server
|
|
- **Generate Authelia secrets** (JWT, session, encryption key)
|
|
- **Prompt for admin username, password, and email**
|
|
- **Generate argon2id password hash** (30-60 seconds)
|
|
- Create `/opt/stacks/` directory structure
|
|
- Set up Docker networks (homelab, traefik, dockerproxy, media)
|
|
- Detect NVIDIA GPU and offer driver installation
|
|
|
|
**Important:** The script generates a secure admin password hash that will be used during deployment. Credentials are displayed at the end and saved to a temporary file.
|
|
|
|
6. **Log out and back in** (or run `newgrp docker`)
|
|
> Don't skip this step! Required for Docker group permissions.
|
|
|
|
7. **Deploy homelab**:
|
|
```bash
|
|
./scripts/deploy-homelab.sh
|
|
```
|
|
|
|
**The deploy script automatically:**
|
|
- Creates Docker networks
|
|
- Configures Traefik with your email
|
|
- Generates Authelia admin password (saved to `/opt/stacks/core/authelia/ADMIN_PASSWORD.txt`)
|
|
- Deploys core stack (DuckDNS, Traefik, Authelia, Gluetun)
|
|
- Deploys infrastructure stack (Dockge, Pi-hole, monitoring)
|
|
- Deploys dashboards stack (Homepage, Homarr)
|
|
- Opens Dockge in your browser
|
|
|
|
**Login credentials:**
|
|
- Username: `admin`
|
|
- Password: Check `/opt/stacks/core/authelia/ADMIN_PASSWORD.txt` or see script output
|
|
|
|
**That's it!** Your homelab is ready. Access Dockge at `https://dockge.yourdomain.duckdns.org`
|
|
|
|
## What the Setup Script Does
|
|
|
|
The `setup-homelab.sh` script is a comprehensive first-run configuration tool:
|
|
|
|
**System Preparation:**
|
|
- ✅ Pre-flight checks (internet connectivity, disk space 50GB+)
|
|
- ✅ Updates system packages
|
|
- ✅ Installs required packages (git, curl, etc.)
|
|
- ✅ Installs Docker Engine + Compose V2 (if not present)
|
|
- ✅ Configures user permissions (docker, sudo groups)
|
|
- ✅ Sets up firewall (UFW with SSH, HTTP, HTTPS)
|
|
- ✅ Enables SSH server
|
|
|
|
**Authelia Configuration (Interactive):**
|
|
- ✅ Generates three cryptographic secrets (JWT, session, encryption)
|
|
- ✅ Prompts for admin username (default: admin)
|
|
- ✅ Prompts for secure password with confirmation
|
|
- ✅ Prompts for admin email address
|
|
- ✅ Generates argon2id password hash using Docker (30-60s process)
|
|
- ✅ Validates Docker is available before password operations
|
|
- ✅ Saves credentials securely for deployment script
|
|
|
|
**Infrastructure Setup:**
|
|
- ✅ Creates directory structure (`/opt/stacks/`)
|
|
- ✅ Sets up Docker networks (homelab, traefik, dockerproxy, media)
|
|
- ✅ Detects NVIDIA GPU and offers driver installation
|
|
|
|
**Safety Features:**
|
|
- Skips completed steps (safe to re-run)
|
|
- Timeout handling (60s for Docker operations)
|
|
- Comprehensive error messages with troubleshooting hints
|
|
- Exit on critical failures with clear next steps
|
|
|
|
## Manual Setup (Alternative)
|
|
|
|
If you prefer manual control or the script fails, follow these steps:
|
|
|
|
### Step 1: System Preparation
|
|
```bash
|
|
# Update system
|
|
sudo apt update && sudo apt upgrade -y
|
|
|
|
# Install required packages
|
|
sudo apt install -y curl wget git ufw openssh-server
|
|
|
|
# Enable firewall
|
|
sudo ufw allow ssh
|
|
sudo ufw allow 80/tcp
|
|
sudo ufw allow 443/tcp
|
|
sudo ufw --force enable
|
|
```
|
|
|
|
### Step 2: Install Docker
|
|
```bash
|
|
# Install Docker
|
|
curl -fsSL https://get.docker.com -o get-docker.sh
|
|
sudo sh get-docker.sh
|
|
|
|
# Add user to docker group
|
|
sudo usermod -aG docker $USER
|
|
sudo usermod -aG sudo $USER
|
|
|
|
# Log out and back in, or run: newgrp docker
|
|
```
|
|
|
|
### Step 3: Clone Repository
|
|
```bash
|
|
cd ~
|
|
git clone https://github.com/kelinfoxy/AI-Homelab.git
|
|
cd AI-Homelab
|
|
```
|
|
|
|
### Step 4: Configure Environment
|
|
```bash
|
|
cp .env.example .env
|
|
nano .env # Edit all required variables
|
|
```
|
|
|
|
### Step 5: Create Infrastructure
|
|
```bash
|
|
# Create directories
|
|
sudo mkdir -p /opt/stacks /mnt/{media,database,downloads,backups}
|
|
sudo chown -R $USER:$USER /opt/stacks /mnt
|
|
|
|
# Create networks
|
|
docker network create traefik-network
|
|
docker network create homelab-network
|
|
docker network create media-network
|
|
```
|
|
|
|
### Step 6: Deploy Services
|
|
```bash
|
|
# Deploy core infrastructure
|
|
sudo mkdir -p /opt/stacks/core
|
|
cp docker-compose/core.yml /opt/stacks/core/
|
|
cp -r config-templates/traefik /opt/stacks/core/
|
|
cp -r config-templates/authelia /opt/stacks/core/
|
|
cp .env /opt/stacks/core/
|
|
cd /opt/stacks/core
|
|
docker compose up -d
|
|
|
|
# Deploy infrastructure stack
|
|
sudo mkdir -p /opt/stacks/infrastructure
|
|
cp ../docker-compose/infrastructure.yml /opt/stacks/infrastructure/
|
|
cp ../.env /opt/stacks/infrastructure/
|
|
cd /opt/stacks/infrastructure
|
|
docker compose up -d
|
|
```
|
|
|
|
## Post-Setup Configuration
|
|
|
|
### Access Your Services
|
|
- **Dockge**: `https://dockge.yourdomain.duckdns.org`
|
|
- **Authelia**: `https://auth.yourdomain.duckdns.org`
|
|
- **Traefik**: `https://traefik.yourdomain.duckdns.org`
|
|
|
|
### Configure Authelia
|
|
1. Access `https://auth.yourdomain.duckdns.org`
|
|
2. Set up your admin user
|
|
3. Configure 2FA for security
|
|
|
|
### Deploy Additional Stacks
|
|
Use Dockge to deploy stacks like:
|
|
- `dashboards.yml` - Homepage and Homarr
|
|
- `media.yml` - Plex, Jellyfin, Sonarr, Radarr
|
|
- `productivity.yml` - Nextcloud, Gitea, wikis
|
|
|
|
### Set Up Homepage Widgets
|
|
1. Access Homepage dashboard
|
|
2. Get API keys from services
|
|
3. Configure widgets in `/opt/stacks/dashboards/homepage/config/`
|
|
|
|
## VS Code Integration
|
|
|
|
1. Install VS Code and GitHub Copilot
|
|
2. Open the AI-Homelab repository
|
|
3. Use AI assistance for:
|
|
- Adding new services
|
|
- Configuring Traefik routing
|
|
- Managing Docker stacks
|
|
|
|
## Troubleshooting
|
|
|
|
### Script Issues
|
|
- **Permission denied**: Run with `sudo`
|
|
- **Docker not found**: Log out/in or run `newgrp docker`
|
|
- **Network conflicts**: Check existing networks with `docker network ls`
|
|
|
|
### Service Issues
|
|
- **Can't access services**: Check Traefik dashboard at `https://traefik.yourdomain.duckdns.org`
|
|
- **SSL certificate errors**: Wait 2-5 minutes for wildcard certificate to be obtained from Let's Encrypt
|
|
- Check status: `python3 -c "import json; d=json.load(open('/opt/stacks/core/traefik/acme.json')); print(f'Certificates: {len(d[\"letsencrypt\"][\"Certificates\"])}')"`
|
|
- View logs: `docker exec traefik tail -50 /var/log/traefik/traefik.log | grep certificate`
|
|
- **Authelia login fails**: Check user database configuration at `/opt/stacks/core/authelia/users_database.yml`
|
|
- **"Not secure" warnings**: Clear browser cache or wait for DNS propagation (up to 5 minutes)
|
|
|
|
### Common Fixes
|
|
```bash
|
|
# Restart Docker
|
|
sudo systemctl restart docker
|
|
|
|
# Check service logs
|
|
cd /opt/stacks/stack-name
|
|
docker compose logs -f
|
|
|
|
# Rebuild service
|
|
docker compose up -d --build service-name
|
|
```
|
|
|
|
## Getting Started Checklist
|
|
|
|
- [ ] Run setup script or manual setup
|
|
- [ ] Configure `.env` file
|
|
- [ ] Deploy core infrastructure
|
|
- [ ] Access Dockge web UI
|
|
- [ ] Set up Authelia authentication
|
|
- [ ] Deploy additional stacks as needed
|
|
- [ ] Configure Homepage dashboard
|
|
- [ ] Install VS Code with Copilot
|
|
|
|
## Next Steps
|
|
|
|
1. **Explore services** through Dockge
|
|
2. **Configure backups** with Backrest/Duplicati
|
|
3. **Set up monitoring** with Grafana/Prometheus
|
|
4. **Add external services** via Traefik proxying
|
|
5. **Use AI assistance** for custom configurations
|
|
|
|
Happy homelabbing! 🚀
|
|
|
|
## Deployment Improvements (Round 4)
|
|
|
|
The repository has been enhanced with the following improvements for better user experience:
|
|
|
|
### Automated Configuration
|
|
- **Email Substitution**: Deploy script automatically configures Traefik with your ACME_EMAIL
|
|
- **Password Generation**: Authelia admin password is auto-generated and saved to `/opt/stacks/core/authelia/ADMIN_PASSWORD.txt`
|
|
- **Network Creation**: Docker networks are created automatically before deployment
|
|
|
|
### Volume Path Standardization
|
|
- All compose files now use **relative paths** (e.g., `./service/config`) for portability
|
|
- Stacks work correctly when deployed via Dockge or docker compose
|
|
- Large shared data still uses absolute paths (`/mnt/media`, `/mnt/downloads`)
|
|
|
|
### SSL Certificate Configuration
|
|
- **Default**: HTTP challenge (simple setup, works immediately)
|
|
- **Optional**: DNS challenge for wildcard certificates (see comments in traefik.yml)
|
|
- Certificates are automatically requested and renewed by Traefik
|
|
|
|
### What's Automated
|
|
✅ Docker network creation
|
|
✅ Traefik email configuration
|
|
✅ Authelia password generation
|
|
✅ Domain configuration in Authelia
|
|
✅ Directory structure creation
|
|
✅ Service deployment
|
|
|
|
### What You Configure
|
|
📝 `.env` file with your domain and API keys
|
|
📝 DuckDNS token
|
|
📝 VPN credentials (if using Gluetun)
|
|
📝 Service-specific settings via Dockge
|