Fix: Simplified docker-compose for Coolify with build from GitHub
This commit is contained in:
12
directus.Dockerfile
Normal file
12
directus.Dockerfile
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
FROM directus/directus:11
|
||||||
|
|
||||||
|
USER root
|
||||||
|
|
||||||
|
# Copy scripts and templates
|
||||||
|
COPY --chown=node:node ./directus/scripts /directus/scripts
|
||||||
|
COPY --chown=node:node ./directus/template /directus/template
|
||||||
|
COPY --chown=node:node ./directus/extensions /directus/extensions
|
||||||
|
|
||||||
|
USER node
|
||||||
|
|
||||||
|
WORKDIR /directus
|
||||||
@@ -1,115 +1,88 @@
|
|||||||
version: '3.8'
|
|
||||||
|
|
||||||
services:
|
services:
|
||||||
# ==========================================
|
|
||||||
# DIRECTUS (Headless CMS)
|
|
||||||
# ==========================================
|
|
||||||
directus:
|
directus:
|
||||||
build:
|
build:
|
||||||
context: ./directus
|
context: .
|
||||||
dockerfile: Dockerfile
|
dockerfile: directus.Dockerfile
|
||||||
container_name: spark-directus
|
|
||||||
restart: unless-stopped
|
|
||||||
ports:
|
|
||||||
- "8055:8055"
|
|
||||||
environment:
|
|
||||||
SECRET: ${DIRECTUS_SECRET:-super-secret-key-change-in-production}
|
|
||||||
ADMIN_EMAIL: ${DIRECTUS_ADMIN_EMAIL:-admin@spark.local}
|
|
||||||
ADMIN_PASSWORD: ${DIRECTUS_ADMIN_PASSWORD:-admin}
|
|
||||||
DB_CLIENT: pg
|
|
||||||
DB_HOST: postgres
|
|
||||||
DB_PORT: 5432
|
|
||||||
DB_DATABASE: ${POSTGRES_DB:-spark}
|
|
||||||
DB_USER: ${POSTGRES_USER:-spark}
|
|
||||||
DB_PASSWORD: ${POSTGRES_PASSWORD:-spark}
|
|
||||||
CACHE_ENABLED: "true"
|
|
||||||
CACHE_STORE: redis
|
|
||||||
REDIS_HOST: redis
|
|
||||||
REDIS_PORT: 6379
|
|
||||||
CORS_ENABLED: "true"
|
|
||||||
CORS_ORIGIN: "*"
|
|
||||||
PUBLIC_URL: ${DIRECTUS_PUBLIC_URL:-http://localhost:8055}
|
|
||||||
STORAGE_LOCATIONS: local
|
|
||||||
STORAGE_LOCAL_ROOT: /directus/uploads
|
|
||||||
volumes:
|
volumes:
|
||||||
- directus_uploads:/directus/uploads
|
- 'directus-uploads:/directus/uploads'
|
||||||
- directus_extensions:/directus/extensions
|
- 'directus-extensions:/directus/extensions'
|
||||||
|
- 'directus-templates:/directus/templates'
|
||||||
|
environment:
|
||||||
|
- SERVICE_URL_DIRECTUS_8055
|
||||||
|
- KEY=$SERVICE_BASE64_64_KEY
|
||||||
|
- SECRET=$SERVICE_BASE64_64_SECRET
|
||||||
|
- 'ADMIN_EMAIL=${ADMIN_EMAIL:-admin@example.com}'
|
||||||
|
- ADMIN_PASSWORD=$SERVICE_PASSWORD_ADMIN
|
||||||
|
- DB_CLIENT=postgres
|
||||||
|
- DB_HOST=postgresql
|
||||||
|
- DB_PORT=5432
|
||||||
|
- 'DB_DATABASE=${POSTGRESQL_DATABASE:-directus}'
|
||||||
|
- DB_USER=$SERVICE_USER_POSTGRESQL
|
||||||
|
- DB_PASSWORD=$SERVICE_PASSWORD_POSTGRESQL
|
||||||
|
- REDIS_HOST=redis
|
||||||
|
- REDIS_PORT=6379
|
||||||
|
- WEBSOCKETS_ENABLED=true
|
||||||
|
healthcheck:
|
||||||
|
test:
|
||||||
|
- CMD
|
||||||
|
- wget
|
||||||
|
- '-q'
|
||||||
|
- '--spider'
|
||||||
|
- 'http://127.0.0.1:8055/admin/login'
|
||||||
|
interval: 5s
|
||||||
|
timeout: 20s
|
||||||
|
retries: 10
|
||||||
depends_on:
|
depends_on:
|
||||||
- postgres
|
postgresql:
|
||||||
- redis
|
condition: service_healthy
|
||||||
networks:
|
redis:
|
||||||
- spark-network
|
condition: service_healthy
|
||||||
|
|
||||||
|
postgresql:
|
||||||
|
image: 'postgis/postgis:16-3.4-alpine'
|
||||||
|
platform: linux/amd64
|
||||||
|
volumes:
|
||||||
|
- 'directus-postgresql-data:/var/lib/postgresql/data'
|
||||||
|
environment:
|
||||||
|
- 'POSTGRES_USER=${SERVICE_USER_POSTGRESQL}'
|
||||||
|
- 'POSTGRES_PASSWORD=${SERVICE_PASSWORD_POSTGRESQL}'
|
||||||
|
- 'POSTGRES_DB=${POSTGRESQL_DATABASE:-directus}'
|
||||||
|
healthcheck:
|
||||||
|
test:
|
||||||
|
- CMD-SHELL
|
||||||
|
- 'pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}'
|
||||||
|
interval: 5s
|
||||||
|
timeout: 20s
|
||||||
|
retries: 10
|
||||||
|
|
||||||
|
redis:
|
||||||
|
image: 'redis:7-alpine'
|
||||||
|
command: 'redis-server --appendonly yes'
|
||||||
|
volumes:
|
||||||
|
- 'directus-redis-data:/data'
|
||||||
|
healthcheck:
|
||||||
|
test:
|
||||||
|
- CMD
|
||||||
|
- redis-cli
|
||||||
|
- ping
|
||||||
|
interval: 5s
|
||||||
|
timeout: 20s
|
||||||
|
retries: 10
|
||||||
|
|
||||||
# ==========================================
|
|
||||||
# FRONTEND (Astro SSR)
|
|
||||||
# ==========================================
|
|
||||||
frontend:
|
frontend:
|
||||||
build:
|
build:
|
||||||
context: ./frontend
|
context: ./frontend
|
||||||
dockerfile: Dockerfile
|
dockerfile: Dockerfile
|
||||||
container_name: spark-frontend
|
|
||||||
restart: unless-stopped
|
|
||||||
ports:
|
|
||||||
- "4321:4321"
|
|
||||||
environment:
|
environment:
|
||||||
PUBLIC_DIRECTUS_URL: ${DIRECTUS_PUBLIC_URL:-http://directus:8055}
|
- PUBLIC_DIRECTUS_URL=http://directus:8055
|
||||||
DIRECTUS_ADMIN_TOKEN: ${DIRECTUS_ADMIN_TOKEN:-}
|
- DIRECTUS_ADMIN_TOKEN=${DIRECTUS_ADMIN_TOKEN:-}
|
||||||
PUBLIC_PLATFORM_DOMAIN: ${PLATFORM_DOMAIN:-localhost}
|
- PUBLIC_PLATFORM_DOMAIN=${PLATFORM_DOMAIN:-localhost}
|
||||||
depends_on:
|
depends_on:
|
||||||
- directus
|
- directus
|
||||||
networks:
|
|
||||||
- spark-network
|
|
||||||
|
|
||||||
# ==========================================
|
|
||||||
# POSTGRESQL DATABASE
|
|
||||||
# ==========================================
|
|
||||||
postgres:
|
|
||||||
image: postgres:16-alpine
|
|
||||||
container_name: spark-postgres
|
|
||||||
restart: unless-stopped
|
|
||||||
environment:
|
|
||||||
POSTGRES_DB: ${POSTGRES_DB:-spark}
|
|
||||||
POSTGRES_USER: ${POSTGRES_USER:-spark}
|
|
||||||
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-spark}
|
|
||||||
volumes:
|
|
||||||
- postgres_data:/var/lib/postgresql/data
|
|
||||||
networks:
|
|
||||||
- spark-network
|
|
||||||
healthcheck:
|
|
||||||
test: [ "CMD-SHELL", "pg_isready -U ${POSTGRES_USER:-spark}" ]
|
|
||||||
interval: 10s
|
|
||||||
timeout: 5s
|
|
||||||
retries: 5
|
|
||||||
|
|
||||||
# ==========================================
|
|
||||||
# REDIS CACHE
|
|
||||||
# ==========================================
|
|
||||||
redis:
|
|
||||||
image: redis:7-alpine
|
|
||||||
container_name: spark-redis
|
|
||||||
restart: unless-stopped
|
|
||||||
volumes:
|
|
||||||
- redis_data:/data
|
|
||||||
networks:
|
|
||||||
- spark-network
|
|
||||||
healthcheck:
|
|
||||||
test: [ "CMD", "redis-cli", "ping" ]
|
|
||||||
interval: 10s
|
|
||||||
timeout: 5s
|
|
||||||
retries: 5
|
|
||||||
|
|
||||||
# ==========================================
|
|
||||||
# VOLUMES
|
|
||||||
# ==========================================
|
|
||||||
volumes:
|
volumes:
|
||||||
postgres_data:
|
directus-uploads:
|
||||||
redis_data:
|
directus-extensions:
|
||||||
directus_uploads:
|
directus-templates:
|
||||||
directus_extensions:
|
directus-postgresql-data:
|
||||||
|
directus-redis-data:
|
||||||
# ==========================================
|
|
||||||
# NETWORKS
|
|
||||||
# ==========================================
|
|
||||||
networks:
|
|
||||||
spark-network:
|
|
||||||
driver: bridge
|
|
||||||
|
|||||||
Reference in New Issue
Block a user