Skip to content

Instantly share code, notes, and snippets.

@flyingwebie
Created October 17, 2025 09:44
Show Gist options
  • Save flyingwebie/1dddf2768c51b61522d587d684fc45d7 to your computer and use it in GitHub Desktop.
Save flyingwebie/1dddf2768c51b61522d587d684fc45d7 to your computer and use it in GitHub Desktop.
Host Twenty CRM in your Coolify system
name: twenty
services:
change-vol-ownership:
image: ubuntu
user: root
restart: "no"
exclude_from_hc: true
volumes:
- server-local-data:/tmp/server-local-data
- docker-data:/tmp/docker-data
command: >
bash -c "
chown -R 1000:1000 /tmp/server-local-data &&
chown -R 1000:1000 /tmp/docker-data &&
echo 'Volume ownership changed successfully'"
networks:
- twenty-network
server:
image: twentycrm/twenty:${TWENTY_VERSION:-latest}
volumes:
- server-local-data:/app/packages/twenty-server/.local-storage
- docker-data:/app/docker-data
environment:
# Coolify magic variables for domain configuration
- SERVICE_FQDN_SERVER_3000
# Application Configuration
- NODE_PORT=3000
- FRONTEND_URL=$SERVICE_FQDN_SERVER
- SERVER_URL=$SERVICE_FQDN_SERVER
# Database Configuration - Auto-generated password by Coolify
- PG_DATABASE_URL=postgres://postgres:$SERVICE_PASSWORD_POSTGRES@db:5432/default
# Redis Configuration
- REDIS_URL=redis://redis:6379
# Required setting for successful startup
- SIGN_IN_PREFILLED=true
# Storage Configuration
- STORAGE_TYPE=${STORAGE_TYPE:-local}
- STORAGE_S3_REGION=${STORAGE_S3_REGION:-}
- STORAGE_S3_NAME=${STORAGE_S3_NAME:-}
- STORAGE_S3_ENDPOINT=${STORAGE_S3_ENDPOINT:-}
# Security - Auto-generated by Coolify (32-char base64 secret)
- APP_SECRET=$SERVICE_BASE64_32_SECRET
# Google OAuth Configuration (Optional)
- MESSAGING_PROVIDER_GMAIL_ENABLED=${MESSAGING_PROVIDER_GMAIL_ENABLED:-false}
- CALENDAR_PROVIDER_GOOGLE_ENABLED=${CALENDAR_PROVIDER_GOOGLE_ENABLED:-false}
- AUTH_GOOGLE_CLIENT_ID=${AUTH_GOOGLE_CLIENT_ID:-}
- AUTH_GOOGLE_CLIENT_SECRET=${AUTH_GOOGLE_CLIENT_SECRET:-}
- AUTH_GOOGLE_CALLBACK_URL=${AUTH_GOOGLE_CALLBACK_URL:-}
- AUTH_GOOGLE_APIS_CALLBACK_URL=${AUTH_GOOGLE_APIS_CALLBACK_URL:-}
# Microsoft OAuth Configuration (Optional)
- CALENDAR_PROVIDER_MICROSOFT_ENABLED=${CALENDAR_PROVIDER_MICROSOFT_ENABLED:-false}
- MESSAGING_PROVIDER_MICROSOFT_ENABLED=${MESSAGING_PROVIDER_MICROSOFT_ENABLED:-false}
- AUTH_MICROSOFT_ENABLED=${AUTH_MICROSOFT_ENABLED:-false}
- AUTH_MICROSOFT_CLIENT_ID=${AUTH_MICROSOFT_CLIENT_ID:-}
- AUTH_MICROSOFT_CLIENT_SECRET=${AUTH_MICROSOFT_CLIENT_SECRET:-}
- AUTH_MICROSOFT_CALLBACK_URL=${AUTH_MICROSOFT_CALLBACK_URL:-}
- AUTH_MICROSOFT_APIS_CALLBACK_URL=${AUTH_MICROSOFT_APIS_CALLBACK_URL:-}
# Email Configuration (Optional)
- EMAIL_FROM_ADDRESS=${EMAIL_FROM_ADDRESS:-}
- EMAIL_FROM_NAME=${EMAIL_FROM_NAME:-}
- EMAIL_SYSTEM_ADDRESS=${EMAIL_SYSTEM_ADDRESS:-}
- EMAIL_DRIVER=${EMAIL_DRIVER:-smtp}
- EMAIL_SMTP_HOST=${EMAIL_SMTP_HOST:-}
- EMAIL_SMTP_PORT=${EMAIL_SMTP_PORT:-465}
- EMAIL_SMTP_USER=${EMAIL_SMTP_USER:-}
- EMAIL_SMTP_PASSWORD=${EMAIL_SMTP_PASSWORD:-}
labels:
- "traefik.enable=true"
- "traefik.http.routers.twenty-server.rule=Host(`${DOMAIN}`)"
- "traefik.http.routers.twenty-server.entrypoints=websecure"
- "traefik.http.routers.twenty-server.tls=true"
- "traefik.http.routers.twenty-server.tls.certresolver=letsencrypt"
- "traefik.http.services.twenty-server.loadbalancer.server.port=3000"
depends_on:
change-vol-ownership:
condition: service_completed_successfully
db:
condition: service_healthy
healthcheck:
test: curl --fail http://localhost:3000/healthz || exit 1
interval: 10s
timeout: 5s
retries: 30
start_period: 40s
restart: always
networks:
- twenty-network
worker:
image: twentycrm/twenty:${TWENTY_VERSION:-latest}
command: ["yarn", "worker:prod"]
volumes:
- server-local-data:/app/packages/twenty-server/.local-storage
- docker-data:/app/docker-data
environment:
# Database Configuration - Reuses same password as server
- PG_DATABASE_URL=postgres://postgres:$SERVICE_PASSWORD_POSTGRES@db:5432/default
# Server URL
- SERVER_URL=$SERVICE_FQDN_SERVER
# Redis Configuration
- REDIS_URL=redis://redis:6379
# Worker runs migrations on server only
- DISABLE_DB_MIGRATIONS=true
# Storage Configuration
- STORAGE_TYPE=${STORAGE_TYPE:-local}
- STORAGE_S3_REGION=${STORAGE_S3_REGION:-}
- STORAGE_S3_NAME=${STORAGE_S3_NAME:-}
- STORAGE_S3_ENDPOINT=${STORAGE_S3_ENDPOINT:-}
# Security - Reuses same secret as server
- APP_SECRET=$SERVICE_BASE64_32_SECRET
# Google OAuth Configuration (Optional)
- MESSAGING_PROVIDER_GMAIL_ENABLED=${MESSAGING_PROVIDER_GMAIL_ENABLED:-false}
- CALENDAR_PROVIDER_GOOGLE_ENABLED=${CALENDAR_PROVIDER_GOOGLE_ENABLED:-false}
- AUTH_GOOGLE_CLIENT_ID=${AUTH_GOOGLE_CLIENT_ID:-}
- AUTH_GOOGLE_CLIENT_SECRET=${AUTH_GOOGLE_CLIENT_SECRET:-}
- AUTH_GOOGLE_CALLBACK_URL=${AUTH_GOOGLE_CALLBACK_URL:-}
- AUTH_GOOGLE_APIS_CALLBACK_URL=${AUTH_GOOGLE_APIS_CALLBACK_URL:-}
# Microsoft OAuth Configuration (Optional)
- CALENDAR_PROVIDER_MICROSOFT_ENABLED=${CALENDAR_PROVIDER_MICROSOFT_ENABLED:-false}
- MESSAGING_PROVIDER_MICROSOFT_ENABLED=${MESSAGING_PROVIDER_MICROSOFT_ENABLED:-false}
- AUTH_MICROSOFT_ENABLED=${AUTH_MICROSOFT_ENABLED:-false}
- AUTH_MICROSOFT_CLIENT_ID=${AUTH_MICROSOFT_CLIENT_ID:-}
- AUTH_MICROSOFT_CLIENT_SECRET=${AUTH_MICROSOFT_CLIENT_SECRET:-}
- AUTH_MICROSOFT_CALLBACK_URL=${AUTH_MICROSOFT_CALLBACK_URL:-}
- AUTH_MICROSOFT_APIS_CALLBACK_URL=${AUTH_MICROSOFT_APIS_CALLBACK_URL:-}
# Email Configuration (Optional)
- EMAIL_FROM_ADDRESS=${EMAIL_FROM_ADDRESS:-}
- EMAIL_FROM_NAME=${EMAIL_FROM_NAME:-}
- EMAIL_SYSTEM_ADDRESS=${EMAIL_SYSTEM_ADDRESS:-}
- EMAIL_DRIVER=${EMAIL_DRIVER:-smtp}
- EMAIL_SMTP_HOST=${EMAIL_SMTP_HOST:-}
- EMAIL_SMTP_PORT=${EMAIL_SMTP_PORT:-465}
- EMAIL_SMTP_USER=${EMAIL_SMTP_USER:-}
- EMAIL_SMTP_PASSWORD=${EMAIL_SMTP_PASSWORD:-}
depends_on:
db:
condition: service_healthy
server:
condition: service_healthy
restart: always
networks:
- twenty-network
db:
image: postgres:16-alpine
volumes:
- db-data:/var/lib/postgresql/data
environment:
# PostgreSQL Configuration
# Password auto-generated by Coolify
- POSTGRES_USER=postgres
- POSTGRES_PASSWORD=$SERVICE_PASSWORD_POSTGRES
- POSTGRES_DB=default
healthcheck:
test: pg_isready -U postgres -h localhost -d default
interval: 5s
timeout: 5s
retries: 10
restart: always
networks:
- twenty-network
redis:
image: redis:7-alpine
volumes:
- redis-data:/data
restart: always
command: ["redis-server", "--maxmemory-policy", "noeviction"]
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 5s
timeout: 5s
retries: 10
networks:
- twenty-network
volumes:
db-data:
redis-data:
server-local-data:
docker-data:
networks:
twenty-network:
driver: bridge
@flyingwebie
Copy link
Author

Only suggestion to use Configure for the container server and set the URL manually https://app.yourdomain.com/

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment