version: "3" x-common: &common networks: - signoz-net deploy: restart_policy: condition: on-failure logging: options: max-size: 50m max-file: "3" x-clickhouse-defaults: &clickhouse-defaults !!merge <<: *common image: clickhouse/clickhouse-server:24.1.2-alpine tty: true deploy: labels: signoz.io/scrape: "true" signoz.io/port: "9363" signoz.io/path: "/metrics" depends_on: - init-clickhouse - zookeeper-1 healthcheck: 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-zookeeper-defaults: &zookeeper-defaults !!merge <<: *common image: bitnami/zookeeper:3.7.1 user: root deploy: labels: signoz.io/scrape: "true" signoz.io/port: "9141" signoz.io/path: "/metrics" healthcheck: test: - CMD-SHELL - curl -s -m 2 http://localhost:8080/commands/ruok | grep error | grep null interval: 30s timeout: 5s retries: 3 x-db-depend: &db-depend !!merge <<: *common depends_on: - clickhouse - schema-migrator services: init-clickhouse: !!merge <<: *common image: clickhouse/clickhouse-server:24.1.2-alpine command: - bash - -c - | version="v0.0.1" node_os=$$(uname -s | tr '[:upper:]' '[:lower:]') node_arch=$$(uname -m | sed s/aarch64/arm64/ | sed s/x86_64/amd64/) echo "Fetching histogram-binary for $${node_os}/$${node_arch}" cd /tmp wget -O histogram-quantile.tar.gz "https://github.com/SigNoz/signoz/releases/download/histogram-quantile%2F$${version}/histogram-quantile_$${node_os}_$${node_arch}.tar.gz" tar -xvzf histogram-quantile.tar.gz mv histogram-quantile /var/lib/clickhouse/user_scripts/histogramQuantile deploy: restart_policy: condition: on-failure volumes: - ../common/clickhouse/user_scripts:/var/lib/clickhouse/user_scripts/ zookeeper-1: !!merge <<: *zookeeper-defaults # ports: # - "2181:2181" # - "2888:2888" # - "3888:3888" volumes: - zookeeper-1:/bitnami/zookeeper environment: - ZOO_SERVER_ID=1 - ALLOW_ANONYMOUS_LOGIN=yes - ZOO_AUTOPURGE_INTERVAL=1 - ZOO_ENABLE_PROMETHEUS_METRICS=yes - ZOO_PROMETHEUS_METRICS_PORT_NUMBER=9141 clickhouse: !!merge <<: *clickhouse-defaults # TODO: needed for clickhouse TCP connectio hostname: clickhouse # ports: # - "9000:9000" # - "8123:8123" # - "9181:9181" volumes: - ../common/clickhouse/config.xml:/etc/clickhouse-server/config.xml - ../common/clickhouse/users.xml:/etc/clickhouse-server/users.xml - ../common/clickhouse/custom-function.xml:/etc/clickhouse-server/custom-function.xml - ../common/clickhouse/user_scripts:/var/lib/clickhouse/user_scripts/ - ../common/clickhouse/cluster.xml:/etc/clickhouse-server/config.d/cluster.xml - clickhouse:/var/lib/clickhouse/ # - ../common/clickhouse/storage.xml:/etc/clickhouse-server/config.d/storage.xml signoz: !!merge <<: *db-depend image: signoz/signoz:v0.76.1 command: - --config=/root/config/prometheus.yml - --use-logs-new-schema=true - --use-trace-new-schema=true ports: - "8080:8080" # signoz port # - "6060:6060" # pprof port volumes: - ../common/signoz/prometheus.yml:/root/config/prometheus.yml - ../common/dashboards:/root/config/dashboards - sqlite:/var/lib/signoz/ environment: - SIGNOZ_ALERTMANAGER_PROVIDER=signoz - SIGNOZ_TELEMETRYSTORE_CLICKHOUSE_DSN=tcp://clickhouse:9000 - SIGNOZ_SQLSTORE_SQLITE_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 otel-collector: !!merge <<: *db-depend image: signoz/signoz-otel-collector:v0.111.34 command: - --config=/etc/otel-collector-config.yaml - --manager-config=/etc/manager-config.yaml - --copy-path=/var/tmp/collector-config.yaml - --feature-gates=-pkg.translator.prometheus.NormalizeName volumes: - ./otel-collector-config.yaml:/etc/otel-collector-config.yaml - ../common/signoz/otel-collector-opamp-config.yaml:/etc/manager-config.yaml environment: - OTEL_RESOURCE_ATTRIBUTES=host.name={{.Node.Hostname}},os.type={{.Node.Platform.OS}} - LOW_CARDINAL_EXCEPTION_GROUPING=false ports: # - "1777:1777" # pprof extension - "4317:4317" # OTLP gRPC receiver - "4318:4318" # OTLP HTTP receiver deploy: replicas: 3 depends_on: - clickhouse - schema-migrator - signoz schema-migrator: !!merge <<: *common image: signoz/signoz-schema-migrator:v0.111.34 deploy: restart_policy: condition: on-failure delay: 5s entrypoint: sh command: - -c - "/signoz-schema-migrator sync --dsn=tcp://clickhouse:9000 --up= && /signoz-schema-migrator async --dsn=tcp://clickhouse:9000 --up=" depends_on: - clickhouse networks: signoz-net: name: signoz-net volumes: clickhouse: name: signoz-clickhouse sqlite: name: signoz-sqlite zookeeper-1: name: signoz-zookeeper-1