Nextcloud
Nextcloud is a self-hosted file storage and sync platform with powerful collaboration capabilities. It integrates Files, Talk, Groupware, Office, Assistant and more into a single platform for remote work and data protection.
Configuration
services:
nextcloud:
image: nextcloud:stable
restart: always
volumes:
- nextcloud_data:/var/www/html
- ../files/fix-nextcloud.sh:/usr/local/bin/fix-nextcloud.sh:ro
environment:
- MYSQL_HOST=nextcloud_db
- MYSQL_DATABASE=nextcloud
- MYSQL_USER=nextcloud
- MYSQL_PASSWORD=${MYSQL_PASSWORD}
depends_on:
- nextcloud_db
- nextcloud_redis
nextcloud_db:
image: mariadb:10.11
restart: always
volumes:
- nextcloud_db_data:/var/lib/mysql
environment:
- MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}
- MYSQL_DATABASE=nextcloud
- MYSQL_USER=nextcloud
- MYSQL_PASSWORD=${MYSQL_PASSWORD}
nextcloud_redis:
image: redis:alpine
restart: always
volumes:
nextcloud_data:
nextcloud_db_data:[variables]
domain_name = "${domain}"
db_password = "${password:32}"
db_root_password = "${password:32}"
region = "DE"
[config]
env = [
"MYSQL_PASSWORD=${db_password}",
"MYSQL_ROOT_PASSWORD=${db_root_password}",
"DEFAULT_PHONE_REGION=${region}",
"NEXTCLOUD_DOMAIN=${domain_name}",
"OVERWRITEPROTOCOL=https",
"TRUSTED_PROXIES=10.0.0.0/8 172.16.0.0/12",
"REDIS_HOST=nextcloud_redis",
"MYSQL_DATABASE=nextcloud",
"MYSQL_USER=nextcloud"
]
[[config.domains]]
serviceName = "nextcloud"
port = 80
host = "${domain_name}"
[[config.mounts]]
filePath = "fix-nextcloud.sh"
content = """#!/bin/sh
#
# Nextcloud Optimization Script
# ==============================
# This script applies production-ready optimizations to Nextcloud.
#
# MANUAL EXECUTION REQUIRED
# -------------------------
# After Nextcloud completes its initial setup (create admin account, etc.),
# run this script manually:
#
# Option 1 (From Dokploy UI):
# 1. Go to your Nextcloud service in Dokploy
# 2. Open the Terminal tab
# 3. Run: su -s /bin/sh www-data -c "/bin/sh /usr/local/bin/fix-nextcloud.sh"
#
# Option 2 (From command line):
# docker exec -u www-data <container-name> /bin/sh /usr/local/bin/fix-nextcloud.sh
#
# Optimizations include:
# - Trusted proxy configuration for reverse proxy support
# - HTTPS protocol override
# - Regional settings (phone region, maintenance window)
# - Performance optimizations (database repair, missing indices)
# - Redis caching configuration (APCu, distributed, locking)
#
# The script is idempotent - it creates a marker file to prevent re-running.
# To re-run manually: delete /var/www/html/data/.nextcloud-optimized and restart container
#
MARKER_FILE="/var/www/html/data/.nextcloud-optimized"
OCC="php /var/www/html/occ"
# Check if already run
if [ -f "$MARKER_FILE" ]; then
echo "Optimizations already applied (marker file exists)."
exit 0
fi
echo "=========================================="
echo " Nextcloud Optimization Script"
echo "=========================================="
echo ""
# Check if running as www-data
CURRENT_USER=$(whoami)
if [ "$CURRENT_USER" = "www-data" ]; then
RUN_AS_WWWDATA=""
else
RUN_AS_WWWDATA="su -s /bin/sh www-data -c"
fi
# Function to run occ command with error handling
run_occ() {
description="$1"
shift
printf " - %s... " "$description"
if [ -z "$RUN_AS_WWWDATA" ]; then
# Already running as www-data
if $OCC "$@" >/dev/null 2>&1; then
echo "✓"
return 0
else
echo "✗ (failed, but continuing)"
return 1
fi
else
# Need to switch to www-data
if $RUN_AS_WWWDATA "$OCC $*" >/dev/null 2>&1; then
echo "✓"
return 0
else
echo "✗ (failed, but continuing)"
return 1
fi
fi
}
# Test database connectivity
echo "[1/5] Testing database connectivity..."
if [ -z "$RUN_AS_WWWDATA" ]; then
if $OCC status >/dev/null 2>&1; then
echo " ✓ Database is accessible"
else
echo " ✗ Database not accessible"
exit 1
fi
else
if $RUN_AS_WWWDATA "$OCC status" >/dev/null 2>&1; then
echo " ✓ Database is accessible"
else
echo " ✗ Database not accessible"
exit 1
fi
fi
# Configure trusted proxies
echo "[2/5] Configuring trusted proxies..."
run_occ "Set trusted proxy 10.0.0.0/8" config:system:set trusted_proxies 0 --value='10.0.0.0/8'
run_occ "Set trusted proxy 172.16.0.0/12" config:system:set trusted_proxies 1 --value='172.16.0.0/12'
run_occ "Set trusted proxy 192.168.0.0/16" config:system:set trusted_proxies 2 --value='192.168.0.0/16'
run_occ "Set HTTPS protocol override" config:system:set overwriteprotocol --value='https'
# Configure regional settings
echo "[3/5] Configuring regional settings..."
run_occ "Set phone region to DE" config:system:set default_phone_region --value='DE'
run_occ "Set maintenance window start" config:system:set maintenance_window_start --value=1 --type=integer
# Run performance optimizations
echo "[4/5] Running performance optimizations..."
echo " - Running maintenance repair (this may take a while)..."
if [ -z "$RUN_AS_WWWDATA" ]; then
if $OCC maintenance:repair --include-expensive 2>&1 | grep -q "No repair steps available"; then
echo " ✓ No repairs needed"
else
echo " ✓ Repair completed"
fi
else
if $RUN_AS_WWWDATA "$OCC maintenance:repair --include-expensive" 2>&1 | grep -q "No repair steps available"; then
echo " ✓ No repairs needed"
else
echo " ✓ Repair completed"
fi
fi
run_occ "Add missing database indices" db:add-missing-indices
# Configure Redis caching
echo "[5/5] Configuring Redis caching..."
run_occ "Set APCu for local cache" config:system:set memcache.local --value='\\OC\\Memcache\\APCu'
run_occ "Set Redis for distributed cache" config:system:set memcache.distributed --value='\\OC\\Memcache\\Redis'
run_occ "Set Redis for locking" config:system:set memcache.locking --value='\\OC\\Memcache\\Redis'
run_occ "Set Redis host" config:system:set redis host --value='nextcloud_redis'
run_occ "Set Redis port" config:system:set redis port --value=6379 --type=integer
# Create marker file
touch "$MARKER_FILE"
echo ""
echo "=========================================="
echo " Optimization Complete!"
echo "=========================================="
echo "All optimizations have been applied."
echo "Marker file created at: $MARKER_FILE"
echo ""
"""Base64
To import this template in Dokploy: create a Compose service → Advanced → Base64 import and paste the content below:
{
  "compose": "services:\n  nextcloud:\n    image: nextcloud:stable\n    restart: always\n    volumes:\n      - nextcloud_data:/var/www/html\n      - ../files/fix-nextcloud.sh:/usr/local/bin/fix-nextcloud.sh:ro\n    environment:\n      - MYSQL_HOST=nextcloud_db\n      - MYSQL_DATABASE=nextcloud\n      - MYSQL_USER=nextcloud\n      - MYSQL_PASSWORD=${MYSQL_PASSWORD}\n    depends_on:\n      - nextcloud_db\n      - nextcloud_redis\n\n  nextcloud_db:\n    image: mariadb:10.11\n    restart: always\n    volumes:\n      - nextcloud_db_data:/var/lib/mysql\n    environment:\n      - MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}\n      - MYSQL_DATABASE=nextcloud\n      - MYSQL_USER=nextcloud\n      - MYSQL_PASSWORD=${MYSQL_PASSWORD}\n\n  nextcloud_redis:\n    image: redis:alpine\n    restart: always\n\nvolumes:\n  nextcloud_data:\n  nextcloud_db_data:",
  "config": "[variables]\n  domain_name = \"${domain}\"\n  db_password = \"${password:32}\"\n  db_root_password = \"${password:32}\"\n  region = \"DE\"\n\n[config]\n  env = [\n    \"MYSQL_PASSWORD=${db_password}\",\n    \"MYSQL_ROOT_PASSWORD=${db_root_password}\",\n    \"DEFAULT_PHONE_REGION=${region}\",\n    \"NEXTCLOUD_DOMAIN=${domain_name}\",\n    \"OVERWRITEPROTOCOL=https\",\n    \"TRUSTED_PROXIES=10.0.0.0/8 172.16.0.0/12\",\n    \"REDIS_HOST=nextcloud_redis\",\n    \"MYSQL_DATABASE=nextcloud\",\n    \"MYSQL_USER=nextcloud\"\n  ]\n\n  [[config.domains]]\n    serviceName = \"nextcloud\"\n    port = 80\n    host = \"${domain_name}\"\n\n  [[config.mounts]]\n    filePath = \"fix-nextcloud.sh\"\n    content = \"\"\"#!/bin/sh\n#\n# Nextcloud Optimization Script\n# ==============================\n# This script applies production-ready optimizations to Nextcloud.\n#\n# MANUAL EXECUTION REQUIRED\n# -------------------------\n# After Nextcloud completes its initial setup (create admin account, etc.),\n# run this script manually:\n#\n# Option 1 (From Dokploy UI):\n#   1. Go to your Nextcloud service in Dokploy\n#   2. Open the Terminal tab\n#   3. Run: su -s /bin/sh www-data -c \"/bin/sh /usr/local/bin/fix-nextcloud.sh\"\n#\n# Option 2 (From command line):\n#   docker exec -u www-data <container-name> /bin/sh /usr/local/bin/fix-nextcloud.sh\n#\n# Optimizations include:\n# - Trusted proxy configuration for reverse proxy support\n# - HTTPS protocol override\n# - Regional settings (phone region, maintenance window)\n# - Performance optimizations (database repair, missing indices)\n# - Redis caching configuration (APCu, distributed, locking)\n#\n# The script is idempotent - it creates a marker file to prevent re-running.\n# To re-run manually: delete /var/www/html/data/.nextcloud-optimized and restart container\n#\n\nMARKER_FILE=\"/var/www/html/data/.nextcloud-optimized\"\nOCC=\"php /var/www/html/occ\"\n\n# Check if already run\nif [ -f \"$MARKER_FILE\" ]; then\n  echo \"Optimizations already applied (marker file exists).\"\n  exit 0\nfi\n\necho \"==========================================\"\necho \"  Nextcloud Optimization Script\"\necho \"==========================================\"\necho \"\"\n\n# Check if running as www-data\nCURRENT_USER=$(whoami)\nif [ \"$CURRENT_USER\" = \"www-data\" ]; then\n  RUN_AS_WWWDATA=\"\"\nelse\n  RUN_AS_WWWDATA=\"su -s /bin/sh www-data -c\"\nfi\n\n# Function to run occ command with error handling\nrun_occ() {\n  description=\"$1\"\n  shift\n  printf \"  - %s... \" \"$description\"\n  if [ -z \"$RUN_AS_WWWDATA\" ]; then\n    # Already running as www-data\n    if $OCC \"$@\" >/dev/null 2>&1; then\n      echo \"✓\"\n      return 0\n    else\n      echo \"✗ (failed, but continuing)\"\n      return 1\n    fi\n  else\n    # Need to switch to www-data\n    if $RUN_AS_WWWDATA \"$OCC $*\" >/dev/null 2>&1; then\n      echo \"✓\"\n      return 0\n    else\n      echo \"✗ (failed, but continuing)\"\n      return 1\n    fi\n  fi\n}\n\n# Test database connectivity\necho \"[1/5] Testing database connectivity...\"\nif [ -z \"$RUN_AS_WWWDATA\" ]; then\n  if $OCC status >/dev/null 2>&1; then\n    echo \"  ✓ Database is accessible\"\n  else\n    echo \"  ✗ Database not accessible\"\n    exit 1\n  fi\nelse\n  if $RUN_AS_WWWDATA \"$OCC status\" >/dev/null 2>&1; then\n    echo \"  ✓ Database is accessible\"\n  else\n    echo \"  ✗ Database not accessible\"\n    exit 1\n  fi\nfi\n\n# Configure trusted proxies\necho \"[2/5] Configuring trusted proxies...\"\nrun_occ \"Set trusted proxy 10.0.0.0/8\" config:system:set trusted_proxies 0 --value='10.0.0.0/8'\nrun_occ \"Set trusted proxy 172.16.0.0/12\" config:system:set trusted_proxies 1 --value='172.16.0.0/12'\nrun_occ \"Set trusted proxy 192.168.0.0/16\" config:system:set trusted_proxies 2 --value='192.168.0.0/16'\nrun_occ \"Set HTTPS protocol override\" config:system:set overwriteprotocol --value='https'\n\n# Configure regional settings\necho \"[3/5] Configuring regional settings...\"\nrun_occ \"Set phone region to DE\" config:system:set default_phone_region --value='DE'\nrun_occ \"Set maintenance window start\" config:system:set maintenance_window_start --value=1 --type=integer\n\n# Run performance optimizations\necho \"[4/5] Running performance optimizations...\"\necho \"  - Running maintenance repair (this may take a while)...\"\nif [ -z \"$RUN_AS_WWWDATA\" ]; then\n  if $OCC maintenance:repair --include-expensive 2>&1 | grep -q \"No repair steps available\"; then\n    echo \"    ✓ No repairs needed\"\n  else\n    echo \"    ✓ Repair completed\"\n  fi\nelse\n  if $RUN_AS_WWWDATA \"$OCC maintenance:repair --include-expensive\" 2>&1 | grep -q \"No repair steps available\"; then\n    echo \"    ✓ No repairs needed\"\n  else\n    echo \"    ✓ Repair completed\"\n  fi\nfi\nrun_occ \"Add missing database indices\" db:add-missing-indices\n\n# Configure Redis caching\necho \"[5/5] Configuring Redis caching...\"\nrun_occ \"Set APCu for local cache\" config:system:set memcache.local --value='\\\\OC\\\\Memcache\\\\APCu'\nrun_occ \"Set Redis for distributed cache\" config:system:set memcache.distributed --value='\\\\OC\\\\Memcache\\\\Redis'\nrun_occ \"Set Redis for locking\" config:system:set memcache.locking --value='\\\\OC\\\\Memcache\\\\Redis'\nrun_occ \"Set Redis host\" config:system:set redis host --value='nextcloud_redis'\nrun_occ \"Set Redis port\" config:system:set redis port --value=6379 --type=integer\n\n# Create marker file\ntouch \"$MARKER_FILE\"\n\necho \"\"\necho \"==========================================\"\necho \"  Optimization Complete!\"\necho \"==========================================\"\necho \"All optimizations have been applied.\"\necho \"Marker file created at: $MARKER_FILE\"\necho \"\"\n\"\"\""
}Links
Tags
file-manager, sync
Version: stable