Ansible role for VictoriaMetrics
This role can manage:
- Single-node installations
- Cluster installations
- Vmutils installations:
- vmalert
- vmagent
- vmauth
- vmbackup (installation only)
- vmrestore (installation only)
- vmctl (installation only)
Or even all of that at once on single node, if for some reason you need it.
This role is compatible with any modern systemd-based distro using arm64 or amd64.
At 12/12/2023, old method of configuring apps with arguments was deprecated. Instead, environment variables will be used.
Transition to new env-based mode should be smooth (at least i tried to keep full compatibility), since it should support all old parameters, but if you want to preserve old arguments-based configuration system, set
victoriametrics_global_config_mode: args
You can also override it per service (search for "_config_mode" in variables). However, there is no guarantee that this method of configuration won't be removed in the future.
Old _args variables, like victoriametrics_cluster_vmstorage_args, will still work with both old and new configuration method, however, you can also use new _envs variables like victoriametrics_cluster_vmstorage_envs to configure additional parameters for victoriametrics components. For info about that parameters, refer to official victoriametrics docs
Installing victoriametrics in single mode is as easy as setting
victoriametrics_singlenode: true
And running this role. It will create user, systemd config, create folder for data and start listening on 127.0.0.1:8428 for both write and read requests.
Role variables related to single-node setup:
Variable name | Default value | Description |
---|---|---|
victoriametrics_singlenode | false |
installs single node if set to true |
victoriametrics_user | victoriametrics |
victoriametrics system user |
victoriametrics_group | {{ victoriametrics_cluster_user }} |
victoriametrics system group |
victoriametrics_version | 1.95.1 |
victoriametrics version |
victoriametrics_retention_period | 3 |
data retention period in months |
victoriametrics_storage_data_path | /var/lib/victoria-metrics |
path to victoriametrics data dir |
victoriametrics_args | {} |
optional args to pass to victoriametrics |
victoriametrics_http_listen_addr | 127.0.0.1:8428 |
port to listen on |
Role variables related to cluster:
Variable name | Default value | Description |
---|---|---|
victoriametrics_cluster | false |
indicates this node is part of cluster |
victoriametrics_cluster_user | {{ victoriametrics_user }} |
victoriametrics system user |
victoriametrics_cluster_group | {{ victoriametrics_group }} |
victoriametrics system group |
victoriametrics_cluster_version | {{ victoriametrics_version }} |
victoriametrics version |
victoriametrics_cluster_vmstorage | false |
installs and configures vmstorage if set to true |
victoriametrics_cluster_vmstorage_retention_period | 3 |
vmstorage retention period (months) |
victoriametrics_cluster_vmstorage_storage_data_path | /var/lib/victoria-metrics |
directory where vmstorage stores metrics |
victoriametrics_cluster_vmstorage_http_listen_addr | 0.0.0.0:8482 |
address where vmstorage http should listen |
victoriametrics_cluster_vmstorage_vminsert_addr | 0.0.0.0:8400 |
address where vmstorage should listen for vminsert |
victoriametrics_cluster_vmstorage_vmselect_addr | 0.0.0.0:8401 |
address where vmstorage should listen for vmselect |
victoriametrics_cluster_vmstorage_args | {} |
additional arguments for vmstorage |
victoriametrics_cluster_vmstorage_envs | {} |
additional environment variables for vmstorage |
victoriametrics_cluster_vminsert | false |
installs and configures vminsert if set to true |
victoriametrics_cluster_vminsert_http_listen_addr | 0.0.0.0:8480 |
address where vminsert http should listen |
victoriametrics_cluster_vminsert_storage_node | - localhost:8400 |
array of vmstorage nodes to connect |
victoriametrics_cluster_vminsert_args | {} |
additional arguments for vminsert |
victoriametrics_cluster_vminsert_envs | {} |
additional environment variables for vminsert |
victoriametrics_cluster_vmselect | false |
installs and configure vmselect if set to true |
victoriametrics_cluster_vmselect_http_listen_addr | 0.0.0.0:8481 |
address where vmselect http should listen |
victoriametrics_cluster_vmselect_storage_node | - localhost:8401 |
array of vmstorage nodes to connect |
victoriametrics_cluster_vmselect_args | {} |
additional arguments for vmselect |
victoriametrics_cluster_vmselect_envs | {} |
additional environment variables for vmselect |
Installing cluster is a bit more complex. You will need setting at least this parameters to true:
victoriametrics_cluster: true
victoriametrics_cluster_vmstorage: true
victoriametrics_cluster_vminsert: true
victoriametrics_cluster_vmselect: true
This will install vmstorage, vminsert, vmselect, create directory for vmstorage, configure vmselect and vminsert to connect to local vmstorage node.
Victoriametrics cluster version will be inherited from victoriametrics_version by default.
Essentially you will get single-node "cluster".
But if you're looking at cluster settings you're probably looking to spread them among multiple servers, so here is an example on how to do that:
Example inventory:
[victoriametrics:children]
victoriametrics-vmstorage
victoriametrics-vmselect
victoriametrics-vminsert
[victoriametrics-vmstorage]
storage_node1
storage_node2
storage_node3
[victoriametrics-vminsert]
insert_node1
insert_node2
[victoriametrics-vmselect]
select_node1
select_node2
In victoriametrics define following group_vars:
victoriametric_cluster: true
victoriametrics_cluster_vmselect_storage_node:
- storage_node1:8400
- storage_node2:8400
- storage_node3:8400
victoriametrics_cluster_vminsert_storage_node:
- storage_node1:8401
- storage_node2:8401
- storage_node3:8401
In victoriametrics-vmstorage group_vars:
victoriametrics_cluster_vmstorage: true
In victoriametrics-vminsert group_vars:
victoriametrics_cluster_vminsert: true
In victoriametrics-vmselect group_vars:
victoriametrics_cluster_vmselect: true
This will end up with 2 select and 2 insert nodes, connected to 3 storage nodes. Of course this is just an example and you're free to use those vars wherever you want - in playbook vars, directly in inventory or in host_vars.
Setting
victoriametrics_vmutils: true
Will install victoriametrics vmutils binaries (vmbackup, vmrestore, vmagent, vmauth, vmalert). It inherits version from victoriametrics_version and permissions from victoriametrics_users/victoriametrics_group. You can control which packages to install with victoriametrics_vmutils_files array, ie:
victoriametrics_vmutils_files:
- vmagent
- vmalert
- vmauth
- vmbackup
- vmrestore
vmauth-related variables:
Variable name | Default value | Description |
---|---|---|
victoriametrics_vmauth | false |
enables vmauth if set to true |
victoriametrics_vmauth_users | {} |
YAML with users, follow original format |
victoriametrics_vmauth_args | {} |
additional arguments to pass to vmauth |
Sample config:
victoriametrics_vmauth: true
victoriametrics_vmauth_users:
- username: "local-single-node"
password: "password"
url_prefix: "http://localhost:8428"
- username: "cluster-select-account-123"
password: "password"
url_prefix: "http://vmselect:8481/select/123/prometheus"
- username: "cluster-insert-account-42"
password: "password"
url_prefix: "http://vminsert:8480/insert/42/prometheus"
vmagent-related variables:
Variable name | Default value | Description |
---|---|---|
victoriametrics_vmagent | false |
enables vmagent if set to true |
victoriametrics_vmagent_global | {} |
YAML with vmagent global settings |
victoriametrics_vmagent_external_labels | {} |
YAML with vmagent external labels |
victoriametrics_vmagent_remotewrite_url | http://localhost:8428/api/v1/write |
URL to victoriametrics instance for writing |
victoriametrics_vmagent_remotewrite_tmpdatapath | {} |
Folder to keep metrics if remotewrite_url is down |
victoriametrics_vmagent_scrape_configs | {} |
YAML with prometheus scrape_configs |
victoriametrics_vmagent_args | {} |
additional arguments to pass to vmagent |
victoriametrics_vmagent_envs | {} |
additional environment variables to pass to vmagent |
Sample config, adding prometheus label environment=production, setting tmp folder to /var/lib/vmagent/tmp (folder will be created by role with proper permissions), and adding single scrape job from localhost:
victoriametrics_vmagent: true
victoriametrics_vmagent_global:
scrape_interval: 15s
scrape_timeout: 10s
victoriametrics_vmagent_external_labels:
environment: production
victoriametrics_vmagent_remotewrite_url: http://localhost:8428/api/v1/write
victoriametrics_vmagent_remotewrite_tmpdatapath: /var/lib/vmagent/tmp
victoriametrics_vmagent_scrape_configs:
- job_name: "vmagent-scrape"
metrics_path: /metrics
basic_auth:
username: username
password: password
static_configs:
- targets:
- localhost:8429
vmalert-related variables:
Variable name | Default value | Description |
---|---|---|
victoriametrics_vmalert | false |
enables vmalert if set to true |
victoriametrics_vmalert_datasource_url | http://localhost:8428 |
URL with datasource from which vmalert will read metrics |
victoriametrics_vmalert_notifier_url | http://localhost:9093 |
URL with alertmanager instance |
victoriametrics_vmalert_remotewrite_url | http://localhost:8428 |
URL with victoriametrics instance to persist vmalert state |
victoriametrics_vmalert_remoteread_url | http://localhost:8428 |
URL with victoriametrics instance to read vmalert state |
victoriametrics_vmalert_alert_rules | {} |
YAML with prometheus alert rules |
victoriametrics_vmalert_args | {} |
additional arguments to pass to vmalert |
victoriametrics_vmalert_envs | {} |
additional environment variables to pass to vmalert |
Sample config, pointing to local victoriametrics instance for both streaming metrics, persisting vmalert state and local alertmanager instance for sending alerts, with single rule to check for exporters in "down" state:
victoriametrics_vmalert: true
victoriametrics_vmalert_datasource_url: http://localhost:8428
victoriametrics_vmalert_notifier_url: http://localhost:9093
victoriametrics_vmalert_remotewrite_url: http://localhost:8428
victoriametrics_vmalert_remoteread_url: http://localhost:8428
victoriametrics_vmalert_alert_rules:
- alert: Instance down
expr: 'up == 0'
for: 5m
labels:
severity: critical
annotations:
summary: '{% raw %}Exporter down{% endraw %}'
description: '{% raw %}Prometheus node {{ $labels.instance }} is down{% endraw %}'