]>
Commit | Line | Data |
---|---|---|
e8395f02 | 1 | version: "3.3" |
2 | ||
3 | services: | |
e8395f02 | 4 | |
afd4ee86 | 5 | # You can comment this webserver section if you want to use another webserver/proxy |
1a9b141d | 6 | webserver: |
afd4ee86 C |
7 | image: chocobozzz/peertube-webserver:latest |
8 | # If you don't want to use the official image and build one from sources: | |
9 | # build: | |
10 | # context: . | |
11 | # dockerfile: Dockerfile.nginx | |
08c11bec C |
12 | env_file: |
13 | - .env | |
afd4ee86 C |
14 | ports: |
15 | - "80:80" | |
16 | - "443:443" | |
1a9b141d RK |
17 | volumes: |
18 | - type: bind | |
a30995fc RK |
19 | # Switch sources if you downloaded the whole repository |
20 | #source: ../../nginx/peertube | |
21 | source: ./docker-volume/nginx/peertube | |
1a9b141d RK |
22 | target: /etc/nginx/conf.d/peertube.template |
23 | - assets:/var/www/peertube/peertube-latest/client/dist:ro | |
24 | - ./docker-volume/data:/var/www/peertube/storage | |
afd4ee86 C |
25 | - certbot-www:/var/www/certbot |
26 | - ./docker-volume/certbot/conf:/etc/letsencrypt | |
1a9b141d RK |
27 | depends_on: |
28 | - peertube | |
29 | restart: "always" | |
1a9b141d | 30 | |
afd4ee86 C |
31 | # You can comment this certbot section if you want to use another webserver/proxy |
32 | certbot: | |
33 | container_name: certbot | |
34 | image: certbot/certbot | |
35 | volumes: | |
36 | - ./docker-volume/certbot/conf:/etc/letsencrypt | |
37 | - certbot-www:/var/www/certbot | |
38 | restart: unless-stopped | |
39 | entrypoint: /bin/sh -c "trap exit TERM; while :; do certbot renew --webroot -w /var/www/certbot; sleep 12h & wait $${!}; done;" | |
40 | depends_on: | |
41 | - webserver | |
42 | ||
1a9b141d RK |
43 | peertube: |
44 | # If you don't want to use the official image and build one from sources: | |
afd4ee86 C |
45 | # build: |
46 | # context: . | |
47 | # dockerfile: ./support/docker/production/Dockerfile.buster | |
1a9b141d | 48 | image: chocobozzz/peertube:production-buster |
0a0e0d08 C |
49 | # Use a static IP for this container because nginx does not handle proxy host change without reload |
50 | # This container could be restarted on crash or until the postgresql database is ready for connection | |
51 | networks: | |
52 | default: | |
53 | ipv4_address: 172.18.0.42 | |
1a9b141d RK |
54 | env_file: |
55 | - .env | |
56 | # If you provide your own webserver and reverse-proxy, otherwise not suitable for production: | |
57 | #ports: | |
b8f3e6b0 | 58 | # - "80:9000" # serving HTTP |
e8395f02 | 59 | volumes: |
1a9b141d | 60 | - assets:/app/client/dist |
fd5e57bb C |
61 | - ./docker-volume/data:/data |
62 | - ./docker-volume/config:/config | |
e8395f02 | 63 | depends_on: |
ef48a0d5 BB |
64 | - postgres |
65 | - redis | |
fef13f14 | 66 | - postfix |
ef48a0d5 | 67 | restart: "always" |
e8395f02 | 68 | |
ef48a0d5 | 69 | postgres: |
a30995fc | 70 | image: postgres:13-alpine |
e2882b2c L |
71 | env_file: |
72 | - .env | |
e8395f02 | 73 | volumes: |
fd5e57bb | 74 | - ./docker-volume/db:/var/lib/postgresql/data |
ef48a0d5 BB |
75 | restart: "always" |
76 | ||
77 | redis: | |
a30995fc | 78 | image: redis:6-alpine |
ef48a0d5 | 79 | volumes: |
fd5e57bb | 80 | - ./docker-volume/redis:/data |
ef48a0d5 | 81 | restart: "always" |
fef13f14 FA |
82 | |
83 | postfix: | |
84 | image: mwader/postfix-relay | |
e2882b2c L |
85 | env_file: |
86 | - .env | |
cd7ec86f | 87 | volumes: |
88 | - ./docker-volume/opendkim/keys:/etc/opendkim/keys | |
fef13f14 | 89 | restart: "always" |
1bab2bbc FA |
90 | |
91 | networks: | |
92 | default: | |
93 | ipam: | |
94 | driver: default | |
95 | config: | |
b8f3e6b0 | 96 | - subnet: 172.18.0.0/16 |
1a9b141d RK |
97 | |
98 | volumes: | |
99 | assets: | |
afd4ee86 | 100 | certbot-www: |