150 lines
4.4 KiB
YAML
150 lines
4.4 KiB
YAML
version: '3.7'
|
|
|
|
services:
|
|
tipi-reverse-proxy:
|
|
container_name: tipi-reverse-proxy
|
|
image: traefik:v2.8
|
|
restart: unless-stopped
|
|
depends_on:
|
|
- tipi-dashboard
|
|
ports:
|
|
- ${NGINX_PORT:-80}:80
|
|
- ${NGINX_PORT_SSL:-443}:443
|
|
command: --providers.docker
|
|
volumes:
|
|
- /var/run/docker.sock:/var/run/docker.sock:ro
|
|
- ./traefik:/root/.config
|
|
- ./traefik/shared:/shared
|
|
networks:
|
|
- tipi_main_network
|
|
|
|
tipi-db:
|
|
container_name: tipi-db
|
|
image: postgres:14
|
|
restart: unless-stopped
|
|
stop_grace_period: 1m
|
|
ports:
|
|
- ${POSTGRES_PORT:-5432}:5432
|
|
volumes:
|
|
- ./data/postgres:/var/lib/postgresql/data
|
|
environment:
|
|
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
|
|
POSTGRES_USER: tipi
|
|
POSTGRES_DB: tipi
|
|
healthcheck:
|
|
test: ['CMD-SHELL', 'pg_isready -d tipi -U tipi']
|
|
interval: 5s
|
|
timeout: 10s
|
|
retries: 120
|
|
networks:
|
|
- tipi_main_network
|
|
|
|
tipi-redis:
|
|
container_name: tipi-redis
|
|
image: redis:7.2.0
|
|
restart: unless-stopped
|
|
command: redis-server --requirepass ${REDIS_PASSWORD}
|
|
ports:
|
|
- 6379:6379
|
|
volumes:
|
|
- ./data/redis:/data
|
|
healthcheck:
|
|
test: ['CMD', 'redis-cli', 'ping']
|
|
interval: 5s
|
|
timeout: 10s
|
|
retries: 120
|
|
networks:
|
|
- tipi_main_network
|
|
|
|
tipi-worker:
|
|
container_name: tipi-worker
|
|
image: ghcr.io/runtipi/worker:${TIPI_VERSION}
|
|
restart: unless-stopped
|
|
healthcheck:
|
|
test: ['CMD', 'curl', '-f', 'http://localhost:3000/healthcheck']
|
|
interval: 5s
|
|
timeout: 10s
|
|
retries: 120
|
|
start_period: 5s
|
|
depends_on:
|
|
tipi-db:
|
|
condition: service_healthy
|
|
tipi-redis:
|
|
condition: service_healthy
|
|
env_file:
|
|
- .env
|
|
environment:
|
|
NODE_ENV: production
|
|
volumes:
|
|
# Core
|
|
- /proc:/host/proc
|
|
- /var/run/docker.sock:/var/run/docker.sock
|
|
# App
|
|
- ./.env:/app/.env
|
|
- ./state:/app/state
|
|
- ./repos:/app/repos
|
|
- ./apps:/app/apps
|
|
- ./logs:/app/logs
|
|
- ./traefik:/app/traefik
|
|
- ./user-config:/app/user-config
|
|
- ./media:/app/media
|
|
- ${STORAGE_PATH:-.}:/storage
|
|
networks:
|
|
- tipi_main_network
|
|
|
|
tipi-dashboard:
|
|
image: ghcr.io/runtipi/runtipi:${TIPI_VERSION}
|
|
restart: unless-stopped
|
|
container_name: tipi-dashboard
|
|
networks:
|
|
- tipi_main_network
|
|
depends_on:
|
|
tipi-db:
|
|
condition: service_healthy
|
|
tipi-redis:
|
|
condition: service_healthy
|
|
tipi-worker:
|
|
condition: service_healthy
|
|
volumes:
|
|
- ./.env:/runtipi/.env:ro
|
|
- ./state:/runtipi/state
|
|
- ./repos:/runtipi/repos:ro
|
|
- ./apps:/runtipi/apps
|
|
- ./logs:/app/logs
|
|
- ${STORAGE_PATH:-.}:/app/storage
|
|
env_file:
|
|
- .env
|
|
environment:
|
|
NODE_ENV: production
|
|
labels:
|
|
# Main
|
|
traefik.enable: true
|
|
traefik.http.middlewares.redirect-to-https.redirectscheme.scheme: https
|
|
traefik.http.services.dashboard.loadbalancer.server.port: 3000
|
|
# Local ip
|
|
traefik.http.routers.dashboard.rule: PathPrefix("/")
|
|
traefik.http.routers.dashboard.service: dashboard
|
|
traefik.http.routers.dashboard.entrypoints: web
|
|
# Websecure
|
|
traefik.http.routers.dashboard-insecure.rule: Host(`${DOMAIN}`) && PathPrefix(`/`)
|
|
traefik.http.routers.dashboard-insecure.service: dashboard
|
|
traefik.http.routers.dashboard-insecure.entrypoints: web
|
|
traefik.http.routers.dashboard-insecure.middlewares: redirect-to-https
|
|
traefik.http.routers.dashboard-secure.rule: Host(`${DOMAIN}`) && PathPrefix(`/`)
|
|
traefik.http.routers.dashboard-secure.service: dashboard
|
|
traefik.http.routers.dashboard-secure.entrypoints: websecure
|
|
traefik.http.routers.dashboard-secure.tls.certresolver: myresolver
|
|
# Local domain
|
|
traefik.http.routers.dashboard-local-insecure.rule: Host(`${LOCAL_DOMAIN}`)
|
|
traefik.http.routers.dashboard-local-insecure.entrypoints: web
|
|
traefik.http.routers.dashboard-local-insecure.service: dashboard
|
|
traefik.http.routers.dashboard-local-insecure.middlewares: redirect-to-https
|
|
traefik.http.routers.dashboard-local.rule: Host(`${LOCAL_DOMAIN}`)
|
|
traefik.http.routers.dashboard-local.entrypoints: websecure
|
|
traefik.http.routers.dashboard-local.tls: true
|
|
traefik.http.routers.dashboard-local.service: dashboard
|
|
|
|
networks:
|
|
tipi_main_network:
|
|
driver: bridge
|
|
name: runtipi_tipi_main_network
|