Initial commit: Windmill setup with Docker Compose
- Add docker-compose.yml for Windmill services - Add Caddyfile for reverse proxy configuration - Add .env for environment variables - Add .gitignore for project
This commit is contained in:
13
.env
Normal file
13
.env
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
DATABASE_URL=postgres://postgres:changeme@db/windmill?sslmode=disable
|
||||||
|
|
||||||
|
# For Enterprise Edition, use:
|
||||||
|
# WM_IMAGE=ghcr.io/windmill-labs/windmill-ee:main
|
||||||
|
WM_IMAGE=ghcr.io/windmill-labs/windmill:main
|
||||||
|
|
||||||
|
|
||||||
|
# To use another port than :80, setup the Caddyfile and the caddy section of the docker-compose to your needs: https://caddyserver.com/docs/getting-started
|
||||||
|
# To have caddy take care of automatic TLS
|
||||||
|
|
||||||
|
# To rotate logs, set the following variables:
|
||||||
|
#LOG_MAX_SIZE=10m
|
||||||
|
#LOG_MAX_FILE=3
|
||||||
30
.gitignore
vendored
Normal file
30
.gitignore
vendored
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
# Docker volumes and data
|
||||||
|
windmill_*/
|
||||||
|
db_data/
|
||||||
|
caddy_data/
|
||||||
|
|
||||||
|
# Environment variables (contains sensitive information)
|
||||||
|
# .env
|
||||||
|
|
||||||
|
# Logs
|
||||||
|
*.log
|
||||||
|
logs/
|
||||||
|
|
||||||
|
# OS files
|
||||||
|
.DS_Store
|
||||||
|
Thumbs.db
|
||||||
|
|
||||||
|
# IDE
|
||||||
|
.vscode/
|
||||||
|
.idea/
|
||||||
|
*.swp
|
||||||
|
*.swo
|
||||||
|
|
||||||
|
# Temporary files
|
||||||
|
*.tmp
|
||||||
|
*.bak
|
||||||
|
*~
|
||||||
|
|
||||||
|
# Resolved markdown files (generated by editor)
|
||||||
|
*.resolved
|
||||||
|
*.resolved.*
|
||||||
35
Caddyfile
Normal file
35
Caddyfile
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
{
|
||||||
|
layer4 {
|
||||||
|
:25 {
|
||||||
|
proxy {
|
||||||
|
to windmill_server:2525
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
{$BASE_URL} {
|
||||||
|
bind {$ADDRESS}
|
||||||
|
|
||||||
|
# LSP - Language Server Protocol for code intelligence (windmill_extra:3001)
|
||||||
|
reverse_proxy /ws/* http://windmill_extra:3001
|
||||||
|
|
||||||
|
# Multiplayer - Real-time collaboration, Enterprise Edition (windmill_extra:3002)
|
||||||
|
# Uncomment and set ENABLE_MULTIPLAYER=true in docker-compose.yml
|
||||||
|
# reverse_proxy /ws_mp/* http://windmill_extra:3002
|
||||||
|
|
||||||
|
# Debugger - Interactive debugging via DAP WebSocket (windmill_extra:3003)
|
||||||
|
# Set ENABLE_DEBUGGER=true in docker-compose.yml to enable
|
||||||
|
handle_path /ws_debug/* {
|
||||||
|
reverse_proxy http://windmill_extra:3003
|
||||||
|
}
|
||||||
|
|
||||||
|
# Search indexer, Enterprise Edition (windmill_indexer:8002)
|
||||||
|
# reverse_proxy /api/srch/* http://windmill_indexer:8002
|
||||||
|
|
||||||
|
# Default: Windmill server
|
||||||
|
reverse_proxy /* http://windmill_server:8000
|
||||||
|
|
||||||
|
# TLS with custom certificates
|
||||||
|
# tls /certs/cert.pem /certs/key.pem
|
||||||
|
}
|
||||||
222
docker-compose.yml
Normal file
222
docker-compose.yml
Normal file
@@ -0,0 +1,222 @@
|
|||||||
|
version: "3.7"
|
||||||
|
|
||||||
|
x-logging: &default-logging
|
||||||
|
driver: "json-file"
|
||||||
|
options:
|
||||||
|
max-size: "${LOG_MAX_SIZE:-20m}"
|
||||||
|
max-file: "${LOG_MAX_FILE:-10}"
|
||||||
|
compress: "true"
|
||||||
|
|
||||||
|
services:
|
||||||
|
db:
|
||||||
|
deploy:
|
||||||
|
# To use an external database, set replicas to 0 and set DATABASE_URL to the external database url in the .env file
|
||||||
|
replicas: 1
|
||||||
|
image: postgres:16
|
||||||
|
shm_size: 1g
|
||||||
|
restart: unless-stopped
|
||||||
|
volumes:
|
||||||
|
- db_data:/var/lib/postgresql/data
|
||||||
|
expose:
|
||||||
|
- 5432
|
||||||
|
environment:
|
||||||
|
POSTGRES_PASSWORD: changeme
|
||||||
|
POSTGRES_DB: windmill
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD-SHELL", "pg_isready -U postgres"]
|
||||||
|
interval: 10s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 5
|
||||||
|
logging: *default-logging
|
||||||
|
|
||||||
|
windmill_server:
|
||||||
|
image: ${WM_IMAGE}
|
||||||
|
pull_policy: always
|
||||||
|
deploy:
|
||||||
|
replicas: 1
|
||||||
|
restart: unless-stopped
|
||||||
|
expose:
|
||||||
|
- 8000
|
||||||
|
- 2525
|
||||||
|
environment:
|
||||||
|
- DATABASE_URL=${DATABASE_URL}
|
||||||
|
- MODE=server
|
||||||
|
depends_on:
|
||||||
|
db:
|
||||||
|
condition: service_healthy
|
||||||
|
volumes:
|
||||||
|
- worker_logs:/tmp/windmill/logs
|
||||||
|
|
||||||
|
logging: *default-logging
|
||||||
|
|
||||||
|
windmill_worker:
|
||||||
|
image: ${WM_IMAGE}
|
||||||
|
pull_policy: always
|
||||||
|
deploy:
|
||||||
|
replicas: 3
|
||||||
|
resources:
|
||||||
|
limits:
|
||||||
|
cpus: "1"
|
||||||
|
memory: 2048M
|
||||||
|
# for GB, use syntax '2Gi'
|
||||||
|
restart: unless-stopped
|
||||||
|
# Uncomment to enable PID namespace isolation (recommended for security)
|
||||||
|
# Requires privileged mode for --mount-proc flag
|
||||||
|
# See: https://www.windmill.dev/docs/advanced/security_isolation
|
||||||
|
# privileged: true
|
||||||
|
environment:
|
||||||
|
- DATABASE_URL=${DATABASE_URL}
|
||||||
|
- MODE=worker
|
||||||
|
- WORKER_GROUP=default
|
||||||
|
# If running with non-root/non-windmill UID (e.g., user: "1001:1001"),
|
||||||
|
# add: - HOME=/tmp
|
||||||
|
# Uncomment to enable PID namespace isolation (requires privileged: true above)
|
||||||
|
# - ENABLE_UNSHARE_PID=true
|
||||||
|
depends_on:
|
||||||
|
db:
|
||||||
|
condition: service_healthy
|
||||||
|
# to mount the worker folder to debug, KEEP_JOB_DIR=true and mount /tmp/windmill
|
||||||
|
volumes:
|
||||||
|
# mount the docker socket to allow to run docker containers from within the workers
|
||||||
|
- /var/run/docker.sock:/var/run/docker.sock
|
||||||
|
- worker_dependency_cache:/tmp/windmill/cache
|
||||||
|
- worker_logs:/tmp/windmill/logs
|
||||||
|
|
||||||
|
logging: *default-logging
|
||||||
|
|
||||||
|
## This worker is specialized for "native" jobs. Native jobs run in-process and thus are much more lightweight than other jobs
|
||||||
|
windmill_worker_native:
|
||||||
|
# Use ghcr.io/windmill-labs/windmill-ee:main for the ee
|
||||||
|
image: ${WM_IMAGE}
|
||||||
|
pull_policy: always
|
||||||
|
deploy:
|
||||||
|
replicas: 1
|
||||||
|
resources:
|
||||||
|
limits:
|
||||||
|
cpus: "1"
|
||||||
|
memory: 2048M
|
||||||
|
# for GB, use syntax '2Gi'
|
||||||
|
restart: unless-stopped
|
||||||
|
# Uncomment to enable PID namespace isolation (recommended for security)
|
||||||
|
# Requires privileged mode for --mount-proc flag
|
||||||
|
# See: https://www.windmill.dev/docs/advanced/security_isolation
|
||||||
|
# privileged: true
|
||||||
|
environment:
|
||||||
|
- DATABASE_URL=${DATABASE_URL}
|
||||||
|
- MODE=worker
|
||||||
|
- WORKER_GROUP=native
|
||||||
|
- NUM_WORKERS=8
|
||||||
|
- SLEEP_QUEUE=200
|
||||||
|
# Uncomment to enable PID namespace isolation (requires privileged: true above)
|
||||||
|
# - ENABLE_UNSHARE_PID=true
|
||||||
|
depends_on:
|
||||||
|
db:
|
||||||
|
condition: service_healthy
|
||||||
|
volumes:
|
||||||
|
- worker_logs:/tmp/windmill/logs
|
||||||
|
logging: *default-logging
|
||||||
|
# This worker is specialized for reports or scraping jobs. It is assigned the "reports" worker group which has an init script that installs chromium and can be targeted by using the "chromium" worker tag.
|
||||||
|
# windmill_worker_reports:
|
||||||
|
# image: ${WM_IMAGE}
|
||||||
|
# pull_policy: always
|
||||||
|
# deploy:
|
||||||
|
# replicas: 1
|
||||||
|
# resources:
|
||||||
|
# limits:
|
||||||
|
# cpus: "1"
|
||||||
|
# memory: 2048M
|
||||||
|
# # for GB, use syntax '2Gi'
|
||||||
|
# restart: unless-stopped
|
||||||
|
# # Uncomment to enable PID namespace isolation (recommended for security)
|
||||||
|
# # Requires privileged mode for --mount-proc flag
|
||||||
|
# # See: https://www.windmill.dev/docs/advanced/security_isolation
|
||||||
|
# # privileged: true
|
||||||
|
# environment:
|
||||||
|
# - DATABASE_URL=${DATABASE_URL}
|
||||||
|
# - MODE=worker
|
||||||
|
# - WORKER_GROUP=reports
|
||||||
|
# # Uncomment to enable PID namespace isolation (requires privileged: true above)
|
||||||
|
# # - ENABLE_UNSHARE_PID=true
|
||||||
|
# depends_on:
|
||||||
|
# db:
|
||||||
|
# condition: service_healthy
|
||||||
|
# # to mount the worker folder to debug, KEEP_JOB_DIR=true and mount /tmp/windmill
|
||||||
|
# volumes:
|
||||||
|
# # mount the docker socket to allow to run docker containers from within the workers
|
||||||
|
# - /var/run/docker.sock:/var/run/docker.sock
|
||||||
|
# - worker_dependency_cache:/tmp/windmill/cache
|
||||||
|
# - worker_logs:/tmp/windmill/logs
|
||||||
|
|
||||||
|
# The indexer powers full-text job and log search, an EE feature.
|
||||||
|
windmill_indexer:
|
||||||
|
image: ${WM_IMAGE}
|
||||||
|
pull_policy: always
|
||||||
|
deploy:
|
||||||
|
replicas: 0 # set to 1 to enable full-text job and log search
|
||||||
|
restart: unless-stopped
|
||||||
|
expose:
|
||||||
|
- 8002
|
||||||
|
environment:
|
||||||
|
- PORT=8002
|
||||||
|
- DATABASE_URL=${DATABASE_URL}
|
||||||
|
- MODE=indexer
|
||||||
|
depends_on:
|
||||||
|
db:
|
||||||
|
condition: service_healthy
|
||||||
|
volumes:
|
||||||
|
- windmill_index:/tmp/windmill/search
|
||||||
|
- worker_logs:/tmp/windmill/logs
|
||||||
|
logging: *default-logging
|
||||||
|
|
||||||
|
# Combined extra services: LSP, Multiplayer, and Debugger
|
||||||
|
# Each service can be enabled/disabled via environment variables:
|
||||||
|
# - ENABLE_LSP=true (default) - Language Server Protocol for code intelligence
|
||||||
|
# - ENABLE_MULTIPLAYER=false - Real-time collaboration (Enterprise Edition)
|
||||||
|
# - ENABLE_DEBUGGER=false - Interactive debugging via DAP WebSocket
|
||||||
|
windmill_extra:
|
||||||
|
image: ghcr.io/windmill-labs/windmill-extra:latest
|
||||||
|
pull_policy: always
|
||||||
|
restart: unless-stopped
|
||||||
|
expose:
|
||||||
|
- 3001 # LSP
|
||||||
|
- 3002 # Multiplayer
|
||||||
|
- 3003 # Debugger
|
||||||
|
environment:
|
||||||
|
- ENABLE_LSP=true
|
||||||
|
- ENABLE_MULTIPLAYER=false # Set to true to enable multiplayer (Enterprise Edition)
|
||||||
|
- ENABLE_DEBUGGER=true # Set to true to enable debugger
|
||||||
|
- DEBUGGER_PORT=3003 # Debugger service port
|
||||||
|
- ENABLE_NSJAIL=false # Set to true for nsjail sandboxing (requires privileged: true)
|
||||||
|
- REQUIRE_SIGNED_DEBUG_REQUESTS=false # Set to true to require JWT tokens for debug sessions
|
||||||
|
- WINDMILL_BASE_URL=http://windmill_server:8000
|
||||||
|
volumes:
|
||||||
|
- lsp_cache:/pyls/.cache
|
||||||
|
logging: *default-logging
|
||||||
|
|
||||||
|
caddy:
|
||||||
|
image: ghcr.io/windmill-labs/caddy-l4:latest
|
||||||
|
restart: unless-stopped
|
||||||
|
# Configure the mounted Caddyfile and the exposed ports or use another reverse proxy if needed
|
||||||
|
volumes:
|
||||||
|
- ./Caddyfile:/etc/caddy/Caddyfile
|
||||||
|
- caddy_data:/data
|
||||||
|
# - ./certs:/certs # Provide custom certificate files like cert.pem and key.pem to enable HTTPS - See the corresponding section in the Caddyfile
|
||||||
|
ports:
|
||||||
|
# To change the exposed port, simply change 80:80 to <desired_port>:80. No other changes needed
|
||||||
|
- 80:80
|
||||||
|
- 25:25
|
||||||
|
# - 443:443 # Uncomment to enable HTTPS handling by Caddy
|
||||||
|
environment:
|
||||||
|
- BASE_URL=":80"
|
||||||
|
# - BASE_URL=":443" # uncomment and comment line above to enable HTTPS via custom certificate and key files
|
||||||
|
# - BASE_URL=mydomain.com # Uncomment and comment line above to enable HTTPS handling by Caddy
|
||||||
|
logging: *default-logging
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
db_data: null
|
||||||
|
worker_dependency_cache: null
|
||||||
|
worker_logs: null
|
||||||
|
worker_memory: null
|
||||||
|
windmill_index: null
|
||||||
|
lsp_cache: null
|
||||||
|
caddy_data: null
|
||||||
Reference in New Issue
Block a user