-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
70 lines (66 loc) · 1.77 KB
/
docker-compose.yml
File metadata and controls
70 lines (66 loc) · 1.77 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
services:
postgres:
image: postgres:15
container_name: n3mo-postgres
environment:
POSTGRES_DB: n3mo
POSTGRES_USER: n3mo
POSTGRES_PASSWORD: n3mo
ports:
- "5432:5432"
healthcheck:
test: ["CMD-SHELL", "pg_isready -U n3mo -d n3mo"]
interval: 5s
timeout: 5s
retries: 5
volumes:
- postgres_data:/var/lib/postgresql/data
elasticsearch:
image: docker.elastic.co/elasticsearch/elasticsearch:8.11.1
container_name: n3mo-es
environment:
- discovery.type=single-node
- xpack.security.enabled=false
- ES_JAVA_OPTS=-Xms512m -Xmx512m
ports:
- "9200:9200"
volumes:
- es_data:/usr/share/elasticsearch/data
healthcheck:
test: ["CMD-SHELL", "curl -fs http://localhost:9200/_cluster/health || exit 1"]
interval: 10s
timeout: 5s
retries: 10
indexer:
build:
context: . # <--- CHANGED: Build from the root now
container_name: n3mo-indexer
depends_on:
- postgres
- elasticsearch
env_file:
- .env
ports:
- "8000:8000" # <--- VITAL: Keeps the Graph Server accessible!
volumes:
- ./src:/app/src:ro # Maps the local source code
# This defaults to scanning the current folder (.) unless you set TARGET_CODE_DIR
- ${TARGET_CODE_DIR:-.}:/app/target_code
db-init:
image: postgres:15
depends_on:
postgres:
condition: service_healthy
volumes:
- ./db:/schema # Maps the db folder from the root
environment:
PGPASSWORD: n3mo
entrypoint: >
bash -c "
echo 'N3MO: Applying database schema...' &&
ls -l /schema &&
psql -h postgres -U n3mo -d n3mo -f /schema/schema.sql
"
volumes:
postgres_data:
es_data: