- Update Caddyfile to use correct syntax for environment variables in GoDaddy DNS settings - Remove unnecessary version declaration from docker-compose.caddy.yml for clarity
60 lines
1.6 KiB
YAML
60 lines
1.6 KiB
YAML
# Docker Compose Konfiguration für Caddy Reverse Proxy
|
|
# Optional: Nur in Produktionsumgebung verwenden
|
|
#
|
|
# Starten: docker compose -f docker-compose.yml -f docker-compose.caddy.yml up -d
|
|
# Stoppen: docker compose -f docker-compose.yml -f docker-compose.caddy.yml down
|
|
|
|
services:
|
|
caddy:
|
|
# Verwende Custom-Image mit GoDaddy DNS-Plugin
|
|
build:
|
|
context: .
|
|
dockerfile: Dockerfile.caddy
|
|
# Alternativ: Verwende Standard-Caddy und manuelle DNS-Konfiguration
|
|
# image: caddy:2-alpine
|
|
container_name: hoerdle-caddy
|
|
restart: unless-stopped
|
|
ports:
|
|
# Standard HTTP/HTTPS Ports
|
|
- "80:80"
|
|
- "443:443"
|
|
- "443:443/udp" # Für HTTP/3 (QUIC)
|
|
environment:
|
|
# GoDaddy API-Credentials für DNS-01 Challenge
|
|
# Diese müssen in einer .env-Datei gesetzt werden:
|
|
# GODADDY_API_KEY=your_api_key
|
|
# GODADDY_API_SECRET=your_api_secret
|
|
- GODADDY_API_KEY=${GODADDY_API_KEY:-}
|
|
- GODADDY_API_SECRET=${GODADDY_API_SECRET:-}
|
|
# Optional: Email für Let's Encrypt Benachrichtigungen
|
|
- CADDY_EMAIL=${CADDY_EMAIL:-}
|
|
volumes:
|
|
# Caddyfile-Konfiguration
|
|
- ./Caddyfile:/etc/caddy/Caddyfile:ro
|
|
# Persistente Zertifikat-Speicherung
|
|
- caddy_data:/data
|
|
- caddy_config:/config
|
|
networks:
|
|
- default
|
|
# Health Check
|
|
healthcheck:
|
|
test: ["CMD", "caddy", "version"]
|
|
interval: 30s
|
|
timeout: 10s
|
|
retries: 3
|
|
# Nur starten, wenn ENABLE_CADDY=true gesetzt ist
|
|
profiles:
|
|
- production
|
|
|
|
volumes:
|
|
caddy_data:
|
|
driver: local
|
|
caddy_config:
|
|
driver: local
|
|
|
|
networks:
|
|
default:
|
|
name: hoerdle_default
|
|
external: true
|
|
|