Compose-Examples/examples/nextcloud/docker-compose-mariadb-redis.yml

81 lines
3.0 KiB
YAML

services:
nextcloud-db:
image: mariadb:lts
container_name: nextcloud-db
hostname: nextcloud-db
command: --transaction-isolation=READ-COMMITTED --innodb_read_only_compressed=OFF
restart: unless-stopped
volumes:
- ${DOCKER_VOLUME_STORAGE:-/mnt/docker-volumes}/nextcloud/database:/var/lib/mysql
environment:
- MYSQL_DATABASE=${MYSQL_DATABASE:-nextcloud}
- MYSQL_USER=${MYSQL_USER:-nextcloud}
- MYSQL_PASSWORD=${MYSQL_PASSWORD:-nextcloud}
- MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD:-nextcloud-root-pw}
- MYSQL_INITDB_SKIP_TZINFO=1
- MARIADB_AUTO_UPGRADE=1
- PUID=${MYSQL_PUID:-1000}
- PGID=${MYSQL_PGID:-1000}
- TZ=${MSQL_TZ:-Europe/Berlin}
#networks:
# - proxy
nextcloud-redis:
image: redis:alpine
container_name: nextcloud-redis
hostname: nextcloud-redis
restart: unless-stopped
command:
- /bin/sh
- -c
- redis-server --requirepass "$${REDIS_PASSWORD:-nextcloud}"
#networks:
# - proxy
nextcloud-app:
image: nextcloud:29-apache
container_name: nextcloud-app
hostname: nextcloud-app
restart: unless-stopped
expose:
- 80/tcp
ports:
- 8080:80
depends_on:
- nextcloud-db
- nextcloud-redis
environment:
- PUID=${NC_PUID:-1000}
- PGID=${NC_PGID:-1000}
- OVERWRITEPROTOCOL=${NC_OVERWRITEPROTOCOL:-http}
- OVERWRITECLIURL=${NC_OVERWRITECLIURL:-http://127.0.0.1:8080}
- OVERWRITEHOST=${NC_OVERWRITEHOST:-127.0.0.1:8080}
- MYSQL_HOST=${MYSQL_HOST:-nextcloud-db}
- MYSQL_DATABASE=${MYSQL_DATABASE:-nextcloud}
- MYSQL_USER=${MYSQL_USER:-nextcloud}
- MYSQL_PASSWORD=${MYSQL_PASSWORD:-nextcloud}
- REDIS_HOST=${REDIS_HOST:-nextcloud-redis}
- REDIS_HOST_PASSWORD=${REDIS_PASSWORD:-nextcloud}
volumes:
- ${DOCKER_VOLUME_STORAGE:-/mnt/docker-volumes}/nextcloud/data:/var/www/html/data
- ${DOCKER_VOLUME_STORAGE:-/mnt/docker-volumes}/nextcloud/app:/var/www/html
#networks:
# - proxy
#labels:
# - traefik.enable=true
# - traefik.http.routers.nextcloud.rule=(Host(`cloud.example.com`)) # pls change
# - traefik.http.services.nextcloud.loadbalancer.server.port=80
# - traefik.http.routers.nextcloud.middlewares=local-ipwhitelist@file,authelia@docker
# - traefik.docker.network=proxy
# - traefik.http.middlewares.nextcloud-dav.replacepathregex.regex=^/.well-known/ca(l|rd)dav
# - traefik.http.middlewares.nextcloud-dav.replacepathregex.replacement=/remote.php/dav/
# - traefik.http.middlewares.limit.buffering.maxRequestBodyBytes=50000000 # only necessary for enabled file uploads
# - traefik.http.middlewares.limit.buffering.maxResponseBodyBytes=50000000 # only necessary for enabled file uploads
# - traefik.http.middlewares.limit.buffering.memRequestBodyBytes=50000000 # only necessary for enabled file uploads
# - traefik.http.middlewares.limit.buffering.memResponseBodyBytes=50000000 # only necessary for enabled file uploads
#networks:
# proxy:
# external: true