initial homelab structure from NAS

This commit is contained in:
2026-03-19 20:20:58 +01:00
parent 087a6e7e73
commit f79b93ecc9
9 changed files with 1244 additions and 0 deletions

View File

@@ -0,0 +1,30 @@
services:
ddns-updater:
image: ghcr.io/qdm12/ddns-updater:latest
container_name: ddns-updater
restart: unless-stopped
networks:
- frontend_net
environment:
TZ: Europe/Berlin
PERIOD: 5m
SERVER_ENABLED: "yes"
LISTENING_ADDRESS: ":8000"
LOG_LEVEL: info
volumes:
- /mnt/user/appdata/ddns-updater:/updater/data
labels:
- "traefik.enable=true"
- "traefik.docker.network=frontend_net"
- "traefik.http.routers.ddns.rule=Host(`ddns.kaleschke.info`)"
- "traefik.http.routers.ddns.entrypoints=websecure"
- "traefik.http.routers.ddns.tls=true"
- "traefik.http.services.ddns.loadbalancer.server.port=8000"
networks:
frontend_net:
external: true

View File

@@ -0,0 +1,62 @@
services:
traefik:
image: traefik:v3.3
container_name: traefik
restart: unless-stopped
command:
- --global.checknewversion=true
- --global.sendanonymoususage=false
- --api.dashboard=true
- --api.insecure=false
- --log.level=INFO
- --providers.docker=true
- --providers.docker.endpoint=unix:///var/run/docker.sock
- --providers.docker.exposedbydefault=false
- --providers.docker.network=frontend_net
- --entrypoints.web.address=:80
- --entrypoints.websecure.address=:443
- --certificatesresolvers.cloudflare.acme.email=michideheld@gmx.de
- --certificatesresolvers.cloudflare.acme.storage=/letsencrypt/acme.json
- --certificatesresolvers.cloudflare.acme.dnschallenge=true
- --certificatesresolvers.cloudflare.acme.dnschallenge.provider=cloudflare
environment:
TZ: Europe/Berlin
CF_DNS_API_TOKEN_FILE: /run/secrets/cloudflare_dns_api_token
secrets:
- cloudflare_dns_api_token
ports:
- "80:80"
- "443:443"
volumes:
- /var/run/docker.sock:/var/run/docker.sock:ro
- /mnt/user/appdata/traefik/acme.json:/letsencrypt/acme.json
networks:
- frontend_net
labels:
- traefik.enable=true
- traefik.docker.network=frontend_net
- traefik.http.routers.traefik.rule=Host(`traefik.kaleschke.info`)
- traefik.http.routers.traefik.entrypoints=websecure
- traefik.http.routers.traefik.tls=true
- traefik.http.routers.traefik.tls.certresolver=cloudflare
- traefik.http.routers.traefik.service=api@internal
secrets:
cloudflare_dns_api_token:
file: /mnt/user/appdata/traefik/secrets/cloudflare_dns_api_token
networks:
frontend_net:
external: true