services-next/docker-compose.yml
2024-02-24 16:12:50 +00:00

117 lines
2.2 KiB
YAML

version: '3.7'
volumes:
#SSL
certs:
acme:
html:
#NextCloud
nc-data:
db-data:
networks:
proxy-tier:
services:
# ============ NextCloud
nextcloud:
image: nextcloud:27.1-fpm
restart: always
volumes:
- nc-data:/var/www/html
environment:
- TRUSTED_PROXIES=palta.cyou
- TRUSTED_DOMAINS=palta.cyou,bard.palta.cyou
- OVERWRITEPROTOCOL=https
- POSTGRES_HOST=db
- REDIS_HOST=redis
env_file:
- db.env
- nc_config.env
networks:
- default
- proxy-tier
depends_on:
- db
- redis
deploy:
resources:
limits:
memory: 1G
nextcloud-janitor:
image: nextcloud:27.1-fpm
restart: always
volumes:
- nc-data:/var/www/html
entrypoint: /cron.sh
depends_on:
- db
- redis
nextcloud-front:
build: ./images/ngx
restart: always
environment:
- VIRTUAL_HOST=palta.cyou
- LETSENCRYPT_HOST=palta.cyou
volumes:
- nc-data:/var/www/html:ro
depends_on:
- nextcloud
networks:
- default
- proxy-tier
# =========== SSL
reverse_proxy:
build: ./images/proxy
restart: always
labels:
com.github.jrcs.letsencrypt_nginx_proxy_companion.nginx_proxy: "true"
volumes:
- certs:/etc/nginx/certs:ro
- ./vhost.d/:/etc/nginx/vhost.d:ro
- html:/usr/share/nginx/html
- /var/run/docker.sock:/tmp/docker.sock:ro
ports:
- 80:80
- 443:443
networks:
- proxy-tier
letsencrypt-companion:
image: docker.io/nginxproxy/acme-companion
restart: always
volumes:
- certs:/etc/nginx/certs
- acme:/etc/acme.sh
- ./vhost.d:/etc/nginx/vhost.d
- html:/usr/share/nginx/html
- /var/run/docker.sock:/var/run/docker.sock:ro
networks:
- proxy-tier
depends_on:
- reverse_proxy
environment:
#- ACME_CA_URI=https://acme-staging-v02.api.letsencrypt.org/directory # test-server
- DEFAULT_EMAIL=admin@uwu.email
db:
image: postgres:14-alpine
restart: always
ports:
- "5432:5432"
volumes:
- db-data:/var/lib/postgresql/data
env_file:
- db.env
shm_size: 256MB
redis:
image: redis:alpine
restart: always