mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-20 15:16:42 +00:00
d4d3ec877e
Signed-off-by: f41gh7 <nik@victoriametrics.com>
168 lines
5.3 KiB
YAML
168 lines
5.3 KiB
YAML
services:
|
|
# Metrics collector.
|
|
# It scrapes targets defined in --promscrape.config
|
|
# And forward them to --remoteWrite.url
|
|
vmagent:
|
|
container_name: vmagent
|
|
image: victoriametrics/vmagent:v1.106.1
|
|
depends_on:
|
|
- "vminsert"
|
|
ports:
|
|
- 8429:8429
|
|
volumes:
|
|
- vmagentdata:/vmagentdata
|
|
- ./prometheus-cluster.yml:/etc/prometheus/prometheus.yml
|
|
command:
|
|
- "--promscrape.config=/etc/prometheus/prometheus.yml"
|
|
- "--remoteWrite.url=http://vminsert:8480/insert/0/prometheus/"
|
|
restart: always
|
|
|
|
# Grafana instance configured with VictoriaMetrics as datasource
|
|
grafana:
|
|
container_name: grafana
|
|
image: grafana/grafana:10.4.2
|
|
depends_on:
|
|
- "vmauth"
|
|
ports:
|
|
- 3000:3000
|
|
restart: always
|
|
volumes:
|
|
- grafanadata:/var/lib/grafana
|
|
- ./provisioning/datasources/prometheus-datasource/cluster.yml:/etc/grafana/provisioning/datasources/cluster.yml
|
|
- ./provisioning/dashboards:/etc/grafana/provisioning/dashboards
|
|
- ./../../dashboards/victoriametrics-cluster.json:/var/lib/grafana/dashboards/vm.json
|
|
- ./../../dashboards/vmagent.json:/var/lib/grafana/dashboards/vmagent.json
|
|
- ./../../dashboards/vmalert.json:/var/lib/grafana/dashboards/vmalert.json
|
|
- ./../../dashboards/vmauth.json:/var/lib/grafana/dashboards/vmauth.json
|
|
|
|
# vmstorage shards. Each shard receives 1/N of all metrics sent to vminserts,
|
|
# where N is number of vmstorages (2 in this case).
|
|
vmstorage-1:
|
|
container_name: vmstorage-1
|
|
image: victoriametrics/vmstorage:v1.106.1-cluster
|
|
ports:
|
|
- 8482
|
|
- 8400
|
|
- 8401
|
|
volumes:
|
|
- strgdata-1:/storage
|
|
command:
|
|
- "--storageDataPath=/storage"
|
|
restart: always
|
|
vmstorage-2:
|
|
container_name: vmstorage-2
|
|
image: victoriametrics/vmstorage:v1.106.1-cluster
|
|
ports:
|
|
- 8482
|
|
- 8400
|
|
- 8401
|
|
volumes:
|
|
- strgdata-2:/storage
|
|
command:
|
|
- "--storageDataPath=/storage"
|
|
restart: always
|
|
|
|
# vminsert is ingestion frontend. It receives metrics pushed by vmagent,
|
|
# pre-process them and distributes across configured vmstorage shards.
|
|
vminsert:
|
|
container_name: vminsert
|
|
image: victoriametrics/vminsert:v1.106.1-cluster
|
|
depends_on:
|
|
- "vmstorage-1"
|
|
- "vmstorage-2"
|
|
command:
|
|
- "--storageNode=vmstorage-1:8400"
|
|
- "--storageNode=vmstorage-2:8400"
|
|
ports:
|
|
- 8480:8480
|
|
restart: always
|
|
|
|
# vmselect is a query fronted. It serves read queries in MetricsQL or PromQL.
|
|
# vmselect collects results from configured `--storageNode` shards.
|
|
vmselect-1:
|
|
container_name: vmselect-1
|
|
image: victoriametrics/vmselect:v1.106.1-cluster
|
|
depends_on:
|
|
- "vmstorage-1"
|
|
- "vmstorage-2"
|
|
command:
|
|
- "--storageNode=vmstorage-1:8401"
|
|
- "--storageNode=vmstorage-2:8401"
|
|
- "--vmalert.proxyURL=http://vmalert:8880"
|
|
ports:
|
|
- 8481
|
|
restart: always
|
|
vmselect-2:
|
|
container_name: vmselect-2
|
|
image: victoriametrics/vmselect:v1.106.1-cluster
|
|
depends_on:
|
|
- "vmstorage-1"
|
|
- "vmstorage-2"
|
|
command:
|
|
- "--storageNode=vmstorage-1:8401"
|
|
- "--storageNode=vmstorage-2:8401"
|
|
- "--vmalert.proxyURL=http://vmalert:8880"
|
|
ports:
|
|
- 8481
|
|
restart: always
|
|
|
|
# vmauth is a router and balancer for HTTP requests.
|
|
# It is configured via --auth.config and balances
|
|
# read requests from Grafana, vmui, vmalert among vmselects.
|
|
# It can be used as an authentication proxy.
|
|
vmauth:
|
|
container_name: vmauth
|
|
image: victoriametrics/vmauth:v1.106.1
|
|
depends_on:
|
|
- "vmselect-1"
|
|
- "vmselect-2"
|
|
volumes:
|
|
- ./auth-cluster.yml:/etc/auth.yml
|
|
command:
|
|
- "--auth.config=/etc/auth.yml"
|
|
ports:
|
|
- 8427:8427
|
|
restart: always
|
|
|
|
# vmalert executes alerting and recording rules
|
|
vmalert:
|
|
container_name: vmalert
|
|
image: victoriametrics/vmalert:v1.106.1
|
|
depends_on:
|
|
- "vmauth"
|
|
ports:
|
|
- 8880:8880
|
|
volumes:
|
|
- ./rules/alerts-cluster.yml:/etc/alerts/alerts.yml
|
|
- ./rules/alerts-health.yml:/etc/alerts/alerts-health.yml
|
|
- ./rules/alerts-vmagent.yml:/etc/alerts/alerts-vmagent.yml
|
|
- ./rules/alerts-vmalert.yml:/etc/alerts/alerts-vmalert.yml
|
|
command:
|
|
- "--datasource.url=http://vmauth:8427/select/0/prometheus"
|
|
- "--remoteRead.url=http://vmauth:8427/select/0/prometheus"
|
|
- "--remoteWrite.url=http://vminsert:8480/insert/0/prometheus"
|
|
- "--notifier.url=http://alertmanager:9093/"
|
|
- "--rule=/etc/alerts/*.yml"
|
|
# display source of alerts in grafana
|
|
- "-external.url=http://127.0.0.1:3000" #grafana outside container
|
|
- '--external.alert.source=explore?orgId=1&left={"datasource":"VictoriaMetrics","queries":[{"expr":{{.Expr|jsonEscape|queryEscape}},"refId":"A"}],"range":{"from":"{{ .ActiveAt.UnixMilli }}","to":"now"}}'
|
|
restart: always
|
|
|
|
# alertmanager receives alerting notifications from vmalert
|
|
# and distributes them according to --config.file.
|
|
alertmanager:
|
|
container_name: alertmanager
|
|
image: prom/alertmanager:v0.27.0
|
|
volumes:
|
|
- ./alertmanager.yml:/config/alertmanager.yml
|
|
command:
|
|
- "--config.file=/config/alertmanager.yml"
|
|
ports:
|
|
- 9093:9093
|
|
restart: always
|
|
|
|
volumes:
|
|
vmagentdata: {}
|
|
strgdata-1: {}
|
|
strgdata-2: {}
|
|
grafanadata: {}
|