-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathdocker-compose.dev.yml
More file actions
123 lines (115 loc) · 3.47 KB
/
docker-compose.dev.yml
File metadata and controls
123 lines (115 loc) · 3.47 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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
name: keynetra-dev
services:
keynetra-api:
build:
context: .
dockerfile: Dockerfile
restart: unless-stopped
working_dir: /app
command: >
uvicorn keynetra.api.main:app
--host 0.0.0.0
--port 8080
--reload
--proxy-headers
--forwarded-allow-ips "*"
ports:
- "8000:8080"
volumes:
- .:/app
environment:
KEYNETRA_ENVIRONMENT: development
KEYNETRA_DEBUG: "true"
KEYNETRA_DATABASE_URL: ${KEYNETRA_DATABASE_URL:-postgresql+psycopg://keynetra:keynetra@postgres:5432/keynetra}
KEYNETRA_REDIS_URL: ${KEYNETRA_REDIS_URL:-redis://redis:6379/0}
KEYNETRA_API_KEYS: ${KEYNETRA_API_KEYS:-devkey}
KEYNETRA_JWT_SECRET: ${KEYNETRA_JWT_SECRET:-change-me}
KEYNETRA_ADMIN_USERNAME: ${KEYNETRA_ADMIN_USERNAME:-admin}
KEYNETRA_ADMIN_PASSWORD: ${KEYNETRA_ADMIN_PASSWORD:-admin123}
KEYNETRA_SERVICE_MODE: ${KEYNETRA_SERVICE_MODE:-all}
KEYNETRA_AUTO_SEED_SAMPLE_DATA: ${KEYNETRA_AUTO_SEED_SAMPLE_DATA:-1}
KEYNETRA_RATE_LIMIT_PER_MINUTE: ${KEYNETRA_RATE_LIMIT_PER_MINUTE:-120}
KEYNETRA_RATE_LIMIT_BURST: ${KEYNETRA_RATE_LIMIT_BURST:-120}
KEYNETRA_RUN_MIGRATIONS: ${KEYNETRA_RUN_MIGRATIONS:-1}
KEYNETRA_SERVER_PORT: ${KEYNETRA_SERVER_PORT:-8080}
depends_on:
postgres:
condition: service_healthy
redis:
condition: service_healthy
postgres:
image: postgres:16
restart: unless-stopped
environment:
POSTGRES_USER: ${KEYNETRA_POSTGRES_USER:-keynetra}
POSTGRES_PASSWORD: ${KEYNETRA_POSTGRES_PASSWORD:-keynetra}
POSTGRES_DB: ${KEYNETRA_POSTGRES_DB:-keynetra}
ports:
- "5432:5432"
volumes:
- postgres_data:/var/lib/postgresql/data
healthcheck:
test: ["CMD-SHELL", "pg_isready -U $$POSTGRES_USER -d $$POSTGRES_DB"]
interval: 10s
timeout: 5s
retries: 5
redis:
image: redis:7-alpine
restart: unless-stopped
ports:
- "6379:6379"
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 10s
timeout: 5s
retries: 5
prometheus:
image: prom/prometheus:v2.55.0
restart: unless-stopped
command:
- --config.file=/etc/prometheus/prometheus.yml
- --storage.tsdb.path=/prometheus
- --web.enable-lifecycle
ports:
- "9090:9090"
volumes:
- ./monitoring/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml:ro
- prometheus_data:/prometheus
depends_on:
keynetra-api:
condition: service_started
grafana:
image: grafana/grafana:11.2.0
restart: unless-stopped
environment:
GF_SECURITY_ADMIN_USER: ${KEYNETRA_GRAFANA_USER:-admin}
GF_SECURITY_ADMIN_PASSWORD: ${KEYNETRA_GRAFANA_PASSWORD:-admin}
GF_USERS_ALLOW_SIGN_UP: "false"
ports:
- "3000:3000"
volumes:
- grafana_data:/var/lib/grafana
- ./monitoring/grafana/provisioning:/etc/grafana/provisioning:ro
- ./monitoring/grafana/dashboards:/var/lib/grafana/dashboards:ro
depends_on:
prometheus:
condition: service_started
node-exporter:
image: prom/node-exporter:v1.8.2
restart: unless-stopped
ports:
- "9100:9100"
loki:
image: grafana/loki:3.2.1
restart: unless-stopped
command: -config.file=/etc/loki/loki-config.yml
ports:
- "3100:3100"
volumes:
- ./monitoring/loki/loki-config.yml:/etc/loki/loki-config.yml:ro
- loki_data:/loki
volumes:
postgres_data:
prometheus_data:
grafana_data:
loki_data: