65 lines
1.7 KiB
YAML
65 lines
1.7 KiB
YAML
|
version: "3.3"
|
||
|
|
||
|
services:
|
||
|
|
||
|
traefik:
|
||
|
image: traefik:1.7-alpine
|
||
|
command: --docker # Tells Træfik to listen to docker
|
||
|
ports:
|
||
|
- "80:80" # The HTTP port
|
||
|
- "443:443" # The HTTPS port
|
||
|
volumes:
|
||
|
- /var/run/docker.sock:/var/run/docker.sock # So that Traefik can listen to the Docker events
|
||
|
- ./docker-volume/traefik/acme.json:/etc/acme.json
|
||
|
- ./traefik.toml:/traefik.toml
|
||
|
restart: "always"
|
||
|
# If you want to use the Traefik dashboard, you should expose it on a
|
||
|
# subdomain with HTTPS and authentification:
|
||
|
# https://medium.com/@xavier.priour/secure-traefik-dashboard-with-https-and-password-in-docker-5b657e2aa15f
|
||
|
# https://github.com/containous/traefik/issues/880#issuecomment-310301168
|
||
|
|
||
|
peertube:
|
||
|
image: chocobozzz/peertube:v1.2.1-stretch
|
||
|
env_file:
|
||
|
- .env
|
||
|
labels:
|
||
|
traefik.enable: "true"
|
||
|
traefik.frontend.rule: "Host:${PEERTUBE_WEBSERVER_HOSTNAME}"
|
||
|
traefik.port: "9000"
|
||
|
volumes:
|
||
|
- ./docker-volume/data:/data
|
||
|
- ./docker-volume/config:/config
|
||
|
depends_on:
|
||
|
- postgres
|
||
|
- redis
|
||
|
- postfix
|
||
|
restart: "always"
|
||
|
|
||
|
postgres:
|
||
|
image: postgres:10-alpine
|
||
|
environment:
|
||
|
POSTGRES_USER: ${PEERTUBE_DB_USERNAME}
|
||
|
POSTGRES_PASSWORD: ${PEERTUBE_DB_PASSWORD}
|
||
|
POSTGRES_DB: peertube
|
||
|
volumes:
|
||
|
- ./docker-volume/db:/var/lib/postgresql/data
|
||
|
restart: "always"
|
||
|
labels:
|
||
|
traefik.enable: "false"
|
||
|
|
||
|
redis:
|
||
|
image: redis:5-alpine
|
||
|
volumes:
|
||
|
- ./docker-volume/redis:/data
|
||
|
restart: "always"
|
||
|
labels:
|
||
|
- "traefik.enable=false"
|
||
|
|
||
|
postfix:
|
||
|
image: mwader/postfix-relay
|
||
|
environment:
|
||
|
- POSTFIX_myhostname=${PEERTUBE_WEBSERVER_HOSTNAME}
|
||
|
labels:
|
||
|
traefik.enable: "false"
|
||
|
restart: "always"
|