peertube.social/templates/docker-compose.yml

82 lines
2.1 KiB
YAML
Raw Normal View History

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:
2019-06-03 21:18:10 +00:00
- /var/run/docker.sock:/var/run/docker.sock:ro
2019-03-12 13:50:38 +00:00
- ./volumes/traefik/acme.json:/etc/acme.json
- ./traefik.toml:/traefik.toml
depends_on:
- nginx
restart: "always"
# Required for view counter to work correctly
# https://github.com/Chocobozzz/PeerTube/issues/1643#issuecomment-464789666
network_mode: "host"
# 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
nginx:
image: nginx:1.15-alpine
volumes:
- ./nginx.conf:/etc/nginx/nginx.conf
labels:
2019-06-03 21:18:10 +00:00
- traefik.enable=true
- traefik.frontend.rule=Host:${PEERTUBE_WEBSERVER_HOSTNAME}
- traefik.port=9000
depends_on:
- peertube
restart: "always"
peertube:
2019-05-23 15:30:08 +00:00
image: chocobozzz/peertube:v1.3.0-rc.2-stretch
env_file:
- .env
volumes:
2019-03-12 13:50:38 +00:00
- ./volumes/data:/data
- /mnt/external:/data-external
- ./volumes/config:/config
2019-04-10 19:43:16 +00:00
environment:
- PEERTUBE_DB_USERNAME=${POSTGRES_USER}
- PEERTUBE_DB_PASSWORD=${POSTGRES_PASSWORD}
depends_on:
- postgres
- redis
- postfix
restart: "always"
postgres:
image: postgres:10-alpine
volumes:
2019-03-12 13:50:38 +00:00
- ./volumes/db:/var/lib/postgresql/data
2019-04-10 19:43:16 +00:00
environment:
- POSTGRES_USER=${POSTGRES_USER}
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
restart: "always"
redis:
image: redis:5-alpine
volumes:
2019-03-12 13:50:38 +00:00
- ./volumes/redis:/data
restart: "always"
postfix:
image: mwader/postfix-relay
environment:
- POSTFIX_myhostname=${PEERTUBE_WEBSERVER_HOSTNAME}
restart: "always"
networks:
default:
ipam:
driver: default
config:
- subnet: 172.18.0.0/16