7 command: --api --docker # Enables the web UI and tells Træfik to listen to docker
9 - "80:80" # The HTTP port
10 - "443:443" # The HTTPS port
11 - "8080:8080" # The Web UI (enabled by --api)
13 - /var/run/docker.sock:/var/run/docker.sock # So that Traefik can listen to the Docker events
14 - ./docker-volume/traefik/acme.json:/etc/acme.json
15 - ./docker-volume/traefik/traefik.toml:/traefik.toml
19 # If you don't want to use the official image and build one from sources
22 # dockerfile: ./support/docker/production/Dockerfile.stretch
23 image: chocobozzz/peertube:production-stretch
25 PEERTUBE_WEBSERVER_HOSTNAME: my.domain.tld
26 PEERTUBE_WEBSERVER_PORT: 443
27 PEERTUBE_WEBSERVER_HTTPS: "true"
28 PEERTUBE_ADMIN_EMAIL: admin@domain.tld
29 PEERTUBE_DB_HOSTNAME: postgres
30 PEERTUBE_DB_USERNAME: postgres_user
31 PEERTUBE_DB_PASSWORD: postgres_password
32 PEERTUBE_SIGNUP_ENABLED: "true"
33 PEERTUBE_TRANSCODING_ENABLED: "true"
34 PEERTUBE_REDIS_HOSTNAME: redis
35 PEERTUBE_SMTP_USERNAME: null
36 PEERTUBE_SMTP_PASSWORD: null
37 PEERTUBE_SMTP_HOSTNAME: null
38 PEERTUBE_SMTP_PORT: 25
39 PEERTUBE_SMTP_FROM: noreply@peertube.domain.tld
40 PEERTUBE_SMTP_TLS: "true"
41 # Traefik labels are suggested as an example for people using Traefik,
42 # remove them if you are using another reverse proxy.
44 traefik.enable: "true"
45 traefik.frontend.rule: "Host:${PEERTUBE_WEBSERVER_HOSTNAME}"
47 # If you don't want to use a reverse proxy (not suitable for production!)
51 - ./docker-volume/data:/data
52 - ./docker-volume/config:/config
59 image: postgres:10-alpine
61 POSTGRES_USER: postgres_user
62 POSTGRES_PASSWORD: postgres_password
65 - ./docker-volume/db:/var/lib/postgresql/data
68 traefik.enable: "false"
73 - ./docker-volume/redis:/data
76 traefik.enable: "false"