-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathcompose.yaml
More file actions
73 lines (70 loc) · 1.9 KB
/
compose.yaml
File metadata and controls
73 lines (70 loc) · 1.9 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
services:
app:
build:
context: .
dockerfile: Dockerfile
container_name: ${CLOUDFLARED_TUNNEL_NAME}-app
restart: unless-stopped
ports:
- "3102:${PORT:-3000}"
environment:
NODE_ENV: production
APP_ENV: production
HOST: 0.0.0.0
PORT: ${PORT:-3000}
WORKERS: ${WORKERS:-0}
DATABASE_PROVIDER: ${DATABASE_PROVIDER:-sqlite}
DATABASE_URL: ${DATABASE_URL:-/app/data/stats.db}
CLOUDFLARE_ACCOUNT_ID: ${CLOUDFLARE_ACCOUNT_ID:-}
CLOUDFLARE_D1_DATABASE_ID: ${CLOUDFLARE_D1_DATABASE_ID:-}
CLOUDFLARE_D1_TOKEN: ${CLOUDFLARE_D1_TOKEN:-}
REDIS_ENABLED: "true"
REDIS_HOST: redis
REDIS_PORT: 6379
GITHUB_TOKEN: ${GITHUB_TOKEN:-}
volumes:
- app-data:/app/data
depends_on:
redis:
condition: service_healthy
healthcheck:
test:
- CMD
- node
- -e
- fetch(`http://127.0.0.1:${PORT:-3000}/health`).then((response)=>process.exit(response.ok?0:1)).catch(()=>process.exit(1))
interval: 30s
timeout: 10s
retries: 5
start_period: 20s
stop_grace_period: 20s
redis:
image: redis:7-alpine
container_name: ${CLOUDFLARED_TUNNEL_NAME}-redis
restart: unless-stopped
command: ["redis-server", "--appendonly", "yes"]
volumes:
- redis-data:/data
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 10s
timeout: 5s
retries: 5
cloudflared:
image: cloudflare/cloudflared:latest
container_name: ${CLOUDFLARED_TUNNEL_NAME}-cloudflared
restart: unless-stopped
network_mode: "service:app"
depends_on:
app:
condition: service_healthy
environment:
TUNNEL_TOKEN: ${CLOUDFLARED_TUNNEL_TOKEN:?Set CLOUDFLARED_TUNNEL_TOKEN in .env}
command:
- tunnel
- --no-autoupdate
- run
- ${CLOUDFLARED_TUNNEL_NAME}
volumes:
app-data:
redis-data: