-
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
89 lines (85 loc) · 3.33 KB
/
docker-compose.yml
File metadata and controls
89 lines (85 loc) · 3.33 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
# =============================================================================
# UNTHREAD WEBHOOK SERVER - DOCKER COMPOSE CONFIGURATION
# =============================================================================
# Complete application stack for the Unthread Webhook Server
#
# Services:
# ┌─ server → Main webhook processing application (builds from source)
# └─ redis-webhook → Redis 8-alpine for webhook message queuing
#
# Docker Container Naming:
# - server → unthread-webhook-server-server-1
# - redis-webhook → unthread-webhook-server-redis-webhook-1
#
# Usage:
# docker-compose up -d # Start all services
# docker-compose logs -f server # View webhook server logs
# docker-compose exec redis-webhook redis-cli
# docker-compose down # Stop all services
# docker-compose down -v # Stop and remove volumes
#
# Prerequisites:
# - Copy .env.example to .env and configure your values
# - Ensure Docker and Docker Compose are installed
#
# =============================================================================
services:
# =============================================================================
# REDIS - WEBHOOK OPERATIONS
# =============================================================================
# Dedicated Redis instance for webhook message queuing and communication
redis-webhook:
image: redis:8-alpine
container_name: unthread-webhook-server-redis-webhook-1
ports:
- "6379:6379"
volumes:
- redis_webhook_data:/data
command: redis-server --appendonly yes # Enable data persistence
restart: unless-stopped
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 30s
timeout: 5s
retries: 5
networks:
- unthread-integration-network
# =============================================================================
# WEBHOOK SERVER APPLICATION
# =============================================================================
# Main Node.js application that handles webhook processing and Redis queuing
server:
image: unthread-webhook-server:latest # Explicit image name for consistency
build:
context: .
container_name: unthread-webhook-server-server-1
ports:
- "3000:3000"
env_file:
- .env
depends_on:
redis-webhook:
condition: service_healthy # Wait for Redis to be ready
restart: unless-stopped
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:3000/health"]
interval: 30s
timeout: 10s
retries: 3
start_period: 40s
networks:
- unthread-integration-network
# =============================================================================
# PERSISTENT VOLUMES
# =============================================================================
# Named volumes for data persistence across container restarts
volumes:
redis_webhook_data: # Redis webhook queue data
# =============================================================================
# NETWORKING
# =============================================================================
# Docker Compose will automatically create and manage this network
networks:
unthread-integration-network:
driver: bridge
name: unthread-integration-network # Use explicit name for consistency