2026-04-29 23:14:14 +00:00
|
|
|
services:
|
|
|
|
|
elasticsearch:
|
|
|
|
|
image: docker.elastic.co/elasticsearch/elasticsearch:8.11.0
|
|
|
|
|
container_name: observability-elasticsearch
|
|
|
|
|
environment:
|
|
|
|
|
- discovery.type=single-node
|
|
|
|
|
- xpack.security.enabled=true
|
|
|
|
|
- ELASTIC_PASSWORD=elastic
|
|
|
|
|
- "ES_JAVA_OPTS=-Xms1g -Xmx1g"
|
|
|
|
|
volumes:
|
|
|
|
|
- elasticsearch_data:/usr/share/elasticsearch/data
|
|
|
|
|
- ./elasticsearch/config/elasticsearch.yml:/usr/share/elasticsearch/config/elasticsearch.yml
|
|
|
|
|
ports:
|
|
|
|
|
- "9200:9200"
|
|
|
|
|
- "9300:9300"
|
|
|
|
|
networks:
|
|
|
|
|
- observability
|
|
|
|
|
restart: unless-stopped
|
|
|
|
|
healthcheck:
|
|
|
|
|
test: ["CMD-SHELL", "curl -f http://localhost:9200/_cluster/health || exit 1"]
|
|
|
|
|
interval: 30s
|
|
|
|
|
timeout: 10s
|
|
|
|
|
retries: 5
|
|
|
|
|
|
|
|
|
|
logstash:
|
|
|
|
|
image: docker.elastic.co/logstash/logstash:8.11.0
|
|
|
|
|
container_name: observability-logstash
|
|
|
|
|
environment:
|
|
|
|
|
- "LS_JAVA_OPTS=-Xms512m -Xmx512m"
|
|
|
|
|
volumes:
|
|
|
|
|
- ./logstash/config/logstash.yml:/usr/share/logstash/config/logstash.yml
|
|
|
|
|
- ./logstash/pipeline:/usr/share/logstash/pipeline
|
|
|
|
|
- ./logs:/usr/share/logstash/logs
|
|
|
|
|
ports:
|
|
|
|
|
- "5044:5044"
|
|
|
|
|
- "8080:8080"
|
|
|
|
|
networks:
|
|
|
|
|
- observability
|
|
|
|
|
depends_on:
|
|
|
|
|
elasticsearch:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
restart: unless-stopped
|
|
|
|
|
healthcheck:
|
|
|
|
|
test: ["CMD-SHELL", "curl -f http://localhost:8080 || exit 1"]
|
|
|
|
|
interval: 30s
|
|
|
|
|
timeout: 10s
|
|
|
|
|
retries: 3
|
|
|
|
|
|
|
|
|
|
kibana:
|
|
|
|
|
image: docker.elastic.co/kibana/kibana:8.11.0
|
|
|
|
|
container_name: observability-kibana
|
|
|
|
|
environment:
|
|
|
|
|
- ELASTICSEARCH_HOSTS=http://elasticsearch:9200
|
|
|
|
|
- ELASTICSEARCH_USERNAME=elastic
|
|
|
|
|
- ELASTICSEARCH_PASSWORD=elastic
|
|
|
|
|
volumes:
|
|
|
|
|
- ./kibana/config/kibana.yml:/usr/share/kibana/config/kibana.yml
|
|
|
|
|
ports:
|
|
|
|
|
- "5601:5601"
|
|
|
|
|
networks:
|
|
|
|
|
- observability
|
|
|
|
|
depends_on:
|
|
|
|
|
elasticsearch:
|
|
|
|
|
condition: service_healthy
|
|
|
|
|
restart: unless-stopped
|
|
|
|
|
healthcheck:
|
|
|
|
|
test: ["CMD-SHELL", "curl -f http://localhost:5601/api/status || exit 1"]
|
|
|
|
|
interval: 30s
|
|
|
|
|
timeout: 10s
|
|
|
|
|
retries: 5
|
|
|
|
|
|
|
|
|
|
grafana:
|
|
|
|
|
image: grafana/grafana:10.2.0
|
|
|
|
|
container_name: observability-grafana
|
|
|
|
|
environment:
|
|
|
|
|
- GF_SECURITY_ADMIN_USER=admin
|
|
|
|
|
- GF_SECURITY_ADMIN_PASSWORD=admin
|
|
|
|
|
- GF_USERS_ALLOW_SIGN_UP=false
|
|
|
|
|
volumes:
|
|
|
|
|
- grafana_data:/var/lib/grafana
|
|
|
|
|
- ./grafana/provisioning:/etc/grafana/provisioning
|
|
|
|
|
- ./grafana/dashboards:/var/lib/grafana/dashboards
|
|
|
|
|
ports:
|
|
|
|
|
- "3000:3000"
|
|
|
|
|
networks:
|
|
|
|
|
- observability
|
|
|
|
|
restart: unless-stopped
|
|
|
|
|
healthcheck:
|
|
|
|
|
test: ["CMD-SHELL", "curl -f http://localhost:3000/api/health || exit 1"]
|
|
|
|
|
interval: 30s
|
|
|
|
|
timeout: 10s
|
|
|
|
|
retries: 3
|
|
|
|
|
|
|
|
|
|
filebeat:
|
|
|
|
|
image: docker.elastic.co/beats/filebeat:8.11.0
|
|
|
|
|
container_name: observability-filebeat
|
|
|
|
|
user: root
|
|
|
|
|
volumes:
|
|
|
|
|
- ./filebeat/config/filebeat.yml:/usr/share/filebeat/filebeat.yml
|
|
|
|
|
- ./logs:/var/log/sample
|
|
|
|
|
- /var/lib/docker/containers:/var/lib/docker/containers:ro
|
|
|
|
|
- /var/run/docker.sock:/var/run/docker.sock:ro
|
|
|
|
|
networks:
|
|
|
|
|
- observability
|
|
|
|
|
depends_on:
|
|
|
|
|
- logstash
|
|
|
|
|
restart: unless-stopped
|
|
|
|
|
|
|
|
|
|
volumes:
|
|
|
|
|
elasticsearch_data:
|
|
|
|
|
driver: local
|
|
|
|
|
grafana_data:
|
|
|
|
|
driver: local
|
|
|
|
|
|
|
|
|
|
networks:
|
|
|
|
|
observability:
|
|
|
|
|
driver: bridge
|
|
|
|
|
ipam:
|
|
|
|
|
config:
|
2026-04-29 23:30:30 +00:00
|
|
|
- subnet: 172.25.0.0/16
|