-
Notifications
You must be signed in to change notification settings - Fork 3
Expand file tree
/
Copy pathdocker-compose.yml
More file actions
93 lines (88 loc) · 2.55 KB
/
docker-compose.yml
File metadata and controls
93 lines (88 loc) · 2.55 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
services:
simian-forge:
build: .
image: simianhacker/simian-forge:latest
container_name: simian-forge
restart: unless-stopped
environment:
- NODE_ENV=production
command: [
"--interval", "${INTERVAL:-10s}",
"--backfill", "${BACKFILL:-now-5m}",
"--count", "${COUNT:-10}",
"--dataset", "${DATASET:-weather}",
"--elasticsearch-url", "${ELASTICSEARCH_URL:-http://elasticsearch:9200}",
"--elasticsearch-auth", "${ELASTICSEARCH_AUTH:-}",
"--elasticsearch-api-key", "${ELASTICSEARCH_API_KEY:-}",
"--collector", "${COLLECTOR:-http://otel-collector:4318}",
"--format", "${FORMAT:-both}"
]
depends_on:
elasticsearch:
condition: service_healthy
otel-collector:
condition: service_started
networks:
- simian-network
profiles:
- full-stack
elasticsearch:
image: docker.elastic.co/elasticsearch/elasticsearch:9.0.3
container_name: elasticsearch
environment:
- discovery.type=single-node
- xpack.security.enabled=false
- xpack.security.enrollment.enabled=false
- "ES_JAVA_OPTS=-Xms1g -Xmx1g"
ports:
- "${ELASTICSEARCH_PORT:-9200}:9200"
volumes:
- elasticsearch-data:/usr/share/elasticsearch/data
networks:
- simian-network
healthcheck:
test: ["CMD-SHELL", "curl -f http://localhost:9200/_cluster/health || exit 1"]
interval: 30s
timeout: 10s
retries: 5
start_period: 60s
profiles:
- full-stack
kibana:
image: docker.elastic.co/kibana/kibana:9.0.3
container_name: kibana
environment:
- ELASTICSEARCH_HOSTS=http://elasticsearch:9200
- ELASTICSEARCH_SECURITY_ENABLED=false
ports:
- "${KIBANA_PORT:-5601}:5601"
depends_on:
elasticsearch:
condition: service_healthy
networks:
- simian-network
profiles:
- full-stack
otel-collector:
image: otel/opentelemetry-collector-contrib:latest
container_name: otel-collector
command: ["--config=/etc/otel-collector-config.yaml"]
volumes:
- ./otel-collector-config.yaml:/etc/otel-collector-config.yaml:ro
ports:
- "${OTEL_GRPC_PORT:-4317}:4317" # OTLP gRPC receiver
- "${OTEL_HTTP_PORT:-4318}:4318" # OTLP HTTP receiver
- "${OTEL_METRICS_PORT:-8889}:8889" # Prometheus metrics
depends_on:
elasticsearch:
condition: service_healthy
networks:
- simian-network
profiles:
- full-stack
volumes:
elasticsearch-data:
driver: local
networks:
simian-network:
driver: bridge