288 lines
7.9 KiB
YAML
288 lines
7.9 KiB
YAML
version: "3.9"
|
|
|
|
x-clickhouse-defaults: &clickhouse-defaults
|
|
image: clickhouse/clickhouse-server:24.1.2-alpine
|
|
tty: true
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
depends_on:
|
|
- zookeeper-1
|
|
# - zookeeper-2
|
|
# - zookeeper-3
|
|
logging:
|
|
options:
|
|
max-size: 50m
|
|
max-file: "3"
|
|
healthcheck:
|
|
# "clickhouse", "client", "-u ${CLICKHOUSE_USER}", "--password ${CLICKHOUSE_PASSWORD}", "-q 'SELECT 1'"
|
|
test:
|
|
[
|
|
"CMD",
|
|
"wget",
|
|
"--spider",
|
|
"-q",
|
|
"0.0.0.0:8123/ping"
|
|
]
|
|
interval: 30s
|
|
timeout: 5s
|
|
retries: 3
|
|
ulimits:
|
|
nproc: 65535
|
|
nofile:
|
|
soft: 262144
|
|
hard: 262144
|
|
|
|
x-db-depend: &db-depend
|
|
depends_on:
|
|
- clickhouse
|
|
- otel-collector-migrator
|
|
# - clickhouse-2
|
|
# - clickhouse-3
|
|
|
|
|
|
services:
|
|
zookeeper-1:
|
|
image: bitnami/zookeeper:3.7.1
|
|
hostname: zookeeper-1
|
|
user: root
|
|
ports:
|
|
- "2181:2181"
|
|
- "2888:2888"
|
|
- "3888:3888"
|
|
volumes:
|
|
- ./data/zookeeper-1:/bitnami/zookeeper
|
|
environment:
|
|
- ZOO_SERVER_ID=1
|
|
# - ZOO_SERVERS=0.0.0.0:2888:3888,zookeeper-2:2888:3888,zookeeper-3:2888:3888
|
|
- ALLOW_ANONYMOUS_LOGIN=yes
|
|
- ZOO_AUTOPURGE_INTERVAL=1
|
|
|
|
# zookeeper-2:
|
|
# image: bitnami/zookeeper:3.7.0
|
|
# hostname: zookeeper-2
|
|
# user: root
|
|
# ports:
|
|
# - "2182:2181"
|
|
# - "2889:2888"
|
|
# - "3889:3888"
|
|
# volumes:
|
|
# - ./data/zookeeper-2:/bitnami/zookeeper
|
|
# environment:
|
|
# - ZOO_SERVER_ID=2
|
|
# - ZOO_SERVERS=zookeeper-1:2888:3888,0.0.0.0:2888:3888,zookeeper-3:2888:3888
|
|
# - ALLOW_ANONYMOUS_LOGIN=yes
|
|
# - ZOO_AUTOPURGE_INTERVAL=1
|
|
|
|
# zookeeper-3:
|
|
# image: bitnami/zookeeper:3.7.0
|
|
# hostname: zookeeper-3
|
|
# user: root
|
|
# ports:
|
|
# - "2183:2181"
|
|
# - "2890:2888"
|
|
# - "3890:3888"
|
|
# volumes:
|
|
# - ./data/zookeeper-3:/bitnami/zookeeper
|
|
# environment:
|
|
# - ZOO_SERVER_ID=3
|
|
# - ZOO_SERVERS=zookeeper-1:2888:3888,zookeeper-2:2888:3888,0.0.0.0:2888:3888
|
|
# - ALLOW_ANONYMOUS_LOGIN=yes
|
|
# - ZOO_AUTOPURGE_INTERVAL=1
|
|
|
|
clickhouse:
|
|
<<: *clickhouse-defaults
|
|
hostname: clickhouse
|
|
# ports:
|
|
# - "9000:9000"
|
|
# - "8123:8123"
|
|
# - "9181:9181"
|
|
volumes:
|
|
- ./clickhouse-config.xml:/etc/clickhouse-server/config.xml
|
|
- ./clickhouse-users.xml:/etc/clickhouse-server/users.xml
|
|
- ./clickhouse-cluster.xml:/etc/clickhouse-server/config.d/cluster.xml
|
|
# - ./clickhouse-storage.xml:/etc/clickhouse-server/config.d/storage.xml
|
|
- ./data/clickhouse/:/var/lib/clickhouse/
|
|
|
|
# clickhouse-2:
|
|
# <<: *clickhouse-defaults
|
|
# hostname: clickhouse-2
|
|
# ports:
|
|
# - "9001:9000"
|
|
# - "8124:8123"
|
|
# - "9182:9181"
|
|
# volumes:
|
|
# - ./clickhouse-config.xml:/etc/clickhouse-server/config.xml
|
|
# - ./clickhouse-users.xml:/etc/clickhouse-server/users.xml
|
|
# - ./clickhouse-cluster.xml:/etc/clickhouse-server/config.d/cluster.xml
|
|
# # - ./clickhouse-storage.xml:/etc/clickhouse-server/config.d/storage.xml
|
|
# - ./data/clickhouse-2/:/var/lib/clickhouse/
|
|
|
|
# clickhouse-3:
|
|
# <<: *clickhouse-defaults
|
|
# hostname: clickhouse-3
|
|
# ports:
|
|
# - "9002:9000"
|
|
# - "8125:8123"
|
|
# - "9183:9181"
|
|
# volumes:
|
|
# - ./clickhouse-config.xml:/etc/clickhouse-server/config.xml
|
|
# - ./clickhouse-users.xml:/etc/clickhouse-server/users.xml
|
|
# - ./clickhouse-cluster.xml:/etc/clickhouse-server/config.d/cluster.xml
|
|
# # - ./clickhouse-storage.xml:/etc/clickhouse-server/config.d/storage.xml
|
|
# - ./data/clickhouse-3/:/var/lib/clickhouse/
|
|
|
|
alertmanager:
|
|
image: signoz/alertmanager:0.23.5
|
|
volumes:
|
|
- ./data/alertmanager:/data
|
|
command:
|
|
- --queryService.url=http://query-service:8085
|
|
- --storage.path=/data
|
|
depends_on:
|
|
- query-service
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
|
|
query-service:
|
|
image: signoz/query-service:0.51.0
|
|
command:
|
|
[
|
|
"-config=/root/config/prometheus.yml",
|
|
# "--prefer-delta=true"
|
|
]
|
|
# ports:
|
|
# - "6060:6060" # pprof port
|
|
# - "8080:8080" # query-service port
|
|
volumes:
|
|
- ./prometheus.yml:/root/config/prometheus.yml
|
|
- ../dashboards:/root/config/dashboards
|
|
- ./data/signoz/:/var/lib/signoz/
|
|
environment:
|
|
- ClickHouseUrl=tcp://clickhouse:9000
|
|
- ALERTMANAGER_API_PREFIX=http://alertmanager:9093/api/
|
|
- SIGNOZ_LOCAL_DB_PATH=/var/lib/signoz/signoz.db
|
|
- DASHBOARDS_PATH=/root/config/dashboards
|
|
- STORAGE=clickhouse
|
|
- GODEBUG=netdns=go
|
|
- TELEMETRY_ENABLED=true
|
|
- DEPLOYMENT_TYPE=docker-swarm
|
|
healthcheck:
|
|
test:
|
|
[
|
|
"CMD",
|
|
"wget",
|
|
"--spider",
|
|
"-q",
|
|
"localhost:8080/api/v1/health"
|
|
]
|
|
interval: 30s
|
|
timeout: 5s
|
|
retries: 3
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
<<: *db-depend
|
|
|
|
frontend:
|
|
image: signoz/frontend:0.48.0
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
depends_on:
|
|
- alertmanager
|
|
- query-service
|
|
ports:
|
|
- "3301:3301"
|
|
volumes:
|
|
- ../common/nginx-config.conf:/etc/nginx/conf.d/default.conf
|
|
|
|
otel-collector:
|
|
image: signoz/signoz-otel-collector:0.102.3
|
|
command:
|
|
[
|
|
"--config=/etc/otel-collector-config.yaml",
|
|
"--manager-config=/etc/manager-config.yaml",
|
|
"--feature-gates=-pkg.translator.prometheus.NormalizeName"
|
|
]
|
|
user: root # required for reading docker container logs
|
|
volumes:
|
|
- ./otel-collector-config.yaml:/etc/otel-collector-config.yaml
|
|
- ./otel-collector-opamp-config.yaml:/etc/manager-config.yaml
|
|
- /var/lib/docker/containers:/var/lib/docker/containers:ro
|
|
environment:
|
|
- OTEL_RESOURCE_ATTRIBUTES=host.name={{.Node.Hostname}},os.type={{.Node.Platform.OS}},dockerswarm.service.name={{.Service.Name}},dockerswarm.task.name={{.Task.Name}}
|
|
- DOCKER_MULTI_NODE_CLUSTER=false
|
|
- LOW_CARDINAL_EXCEPTION_GROUPING=false
|
|
ports:
|
|
# - "1777:1777" # pprof extension
|
|
- "4317:4317" # OTLP gRPC receiver
|
|
- "4318:4318" # OTLP HTTP receiver
|
|
# - "8888:8888" # OtelCollector internal metrics
|
|
# - "8889:8889" # signoz spanmetrics exposed by the agent
|
|
# - "9411:9411" # Zipkin port
|
|
# - "13133:13133" # Health check extension
|
|
# - "14250:14250" # Jaeger gRPC
|
|
# - "14268:14268" # Jaeger thrift HTTP
|
|
# - "55678:55678" # OpenCensus receiver
|
|
# - "55679:55679" # zPages extension
|
|
deploy:
|
|
mode: global
|
|
restart_policy:
|
|
condition: on-failure
|
|
depends_on:
|
|
- clickhouse
|
|
- otel-collector-migrator
|
|
- query-service
|
|
|
|
otel-collector-migrator:
|
|
image: signoz/signoz-schema-migrator:0.102.3
|
|
deploy:
|
|
restart_policy:
|
|
condition: on-failure
|
|
delay: 5s
|
|
command:
|
|
- "--dsn=tcp://clickhouse:9000"
|
|
depends_on:
|
|
- clickhouse
|
|
# - clickhouse-2
|
|
# - clickhouse-3
|
|
|
|
logspout:
|
|
image: "gliderlabs/logspout:v3.2.14"
|
|
volumes:
|
|
- /etc/hostname:/etc/host_hostname:ro
|
|
- /var/run/docker.sock:/var/run/docker.sock
|
|
command: syslog+tcp://otel-collector:2255
|
|
depends_on:
|
|
- otel-collector
|
|
deploy:
|
|
mode: global
|
|
restart_policy:
|
|
condition: on-failure
|
|
|
|
hotrod:
|
|
image: jaegertracing/example-hotrod:1.30
|
|
command: [ "all" ]
|
|
environment:
|
|
- JAEGER_ENDPOINT=http://otel-collector:14268/api/traces
|
|
logging:
|
|
options:
|
|
max-size: 50m
|
|
max-file: "3"
|
|
|
|
load-hotrod:
|
|
image: "signoz/locust:1.2.3"
|
|
hostname: load-hotrod
|
|
environment:
|
|
ATTACKED_HOST: http://hotrod:8080
|
|
LOCUST_MODE: standalone
|
|
NO_PROXY: standalone
|
|
TASK_DELAY_FROM: 5
|
|
TASK_DELAY_TO: 30
|
|
QUIET_MODE: "${QUIET_MODE:-false}"
|
|
LOCUST_OPTS: "--headless -u 10 -r 1"
|
|
volumes:
|
|
- ../common/locust-scripts:/locust
|