- Gitea: data volume moved from local ./data to /mnt/nas/docker-data/gitea/data - Nextcloud app: data volume moved from Docker named volume to /mnt/nas/docker-data/nextcloud/app-data - Nextcloud DB: moved to /mnt/nas/docker-data/nextcloud/db-data with NFS compatibility fixes: - user: 1024:100 to match NAS file ownership and avoid chown failures - innodb_use_native_aio=0 (NFS requirement) - innodb_flush_method=O_DIRECT (better NFS performance) - MARIADB_INITDB_SKIP_TZINFO=1 (avoid tz table load on NFS) - Removed named Docker volumes nextcloud_db and nextcloud_data (replaced by NAS mounts)
85 lines
2.7 KiB
YAML
85 lines
2.7 KiB
YAML
# DEPLOYMENT LOCATION: /opt/docker/nextcloud/docker-compose.yml
|
|
# Deploy with:
|
|
# sudo mkdir -p /opt/docker/nextcloud
|
|
# sudo cp config/docker/nextcloud/docker-compose.yml /opt/docker/nextcloud/
|
|
# sudo cp config/docker/nextcloud/.env /opt/docker/nextcloud/
|
|
# cd /opt/docker/nextcloud && sudo docker-compose up -d
|
|
|
|
services:
|
|
nextcloud-db:
|
|
image: mariadb:10.11
|
|
restart: unless-stopped
|
|
container_name: nextcloud-db
|
|
user: "1024:100" # Match NAS file ownership (uid 1024, gid 100) to bypass chown on NFS
|
|
environment:
|
|
- MYSQL_ROOT_PASSWORD_FILE=/run/secrets/mysql_root_password
|
|
- MYSQL_PASSWORD_FILE=/run/secrets/mysql_password
|
|
- MYSQL_DATABASE=nextcloud
|
|
- MYSQL_USER=nextcloud
|
|
- MARIADB_INITDB_SKIP_TZINFO=1 # Skip timezone loading on NFS
|
|
volumes:
|
|
- /mnt/nas/docker-data/nextcloud/db-data:/var/lib/mysql
|
|
command:
|
|
- --innodb_use_native_aio=0 # Required for NFS
|
|
- --innodb_flush_method=O_DIRECT # Better NFS performance
|
|
networks:
|
|
- nextcloud
|
|
secrets:
|
|
- mysql_root_password
|
|
- mysql_password
|
|
|
|
nextcloud-redis:
|
|
image: redis:7-alpine
|
|
restart: unless-stopped
|
|
container_name: nextcloud-redis
|
|
networks:
|
|
- nextcloud
|
|
|
|
nextcloud-app:
|
|
image: nextcloud:32
|
|
restart: unless-stopped
|
|
container_name: nextcloud-app
|
|
ports:
|
|
- "8083:80"
|
|
environment:
|
|
- MYSQL_PASSWORD_FILE=/run/secrets/mysql_password
|
|
- MYSQL_DATABASE=nextcloud
|
|
- MYSQL_USER=nextcloud
|
|
- MYSQL_HOST=nextcloud-db
|
|
- REDIS_HOST=nextcloud-redis
|
|
- NEXTCLOUD_TRUSTED_DOMAINS=ak-homelab.duckdns.org 192.168.0.100 localhost
|
|
- NEXTCLOUD_ADMIN_USER=hoborg
|
|
- NEXTCLOUD_ADMIN_PASSWORD_FILE=/run/secrets/nextcloud_admin_password
|
|
- OVERWRITEPROTOCOL=https
|
|
- OVERWRITEHOST=ak-homelab.duckdns.org
|
|
- OVERWRITEWEBROOT=/cloud
|
|
volumes:
|
|
- /mnt/nas/docker-data/nextcloud/app-data:/var/www/html
|
|
# External storage mounts for existing folders
|
|
- /home/hoborg/shared:/external_storage/shared:rw
|
|
- /home/hoborg/Documents:/external_storage/documents:rw
|
|
- /home/hoborg/Music:/external_storage/music:rw
|
|
- /home/hoborg/Videos:/external_storage/videos:rw
|
|
- /home/hoborg/Pictures:/external_storage/pictures:rw
|
|
- /home/hoborg/private:/external_storage/private:rw
|
|
depends_on:
|
|
- nextcloud-db
|
|
- nextcloud-redis
|
|
networks:
|
|
- nextcloud
|
|
secrets:
|
|
- mysql_password
|
|
- nextcloud_admin_password
|
|
|
|
secrets:
|
|
mysql_root_password:
|
|
file: /home/hoborg/creds/nextcloud_mysql_root_password.txt
|
|
mysql_password:
|
|
file: /home/hoborg/creds/nextcloud_mysql_password.txt
|
|
nextcloud_admin_password:
|
|
file: /home/hoborg/creds/nextcloud_admin_password.txt
|
|
|
|
networks:
|
|
nextcloud:
|
|
driver: bridge
|