mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-22 08:10:44 +01:00
docs/Single-server-VictoriaMetrics.md: sync with master
This commit is contained in:
parent
dab9a63485
commit
9a02ca67e9
@ -131,14 +131,13 @@ It is recommended setting up [monitoring](#monitoring) for VictoriaMetrics.
|
|||||||
|
|
||||||
### Prometheus setup
|
### Prometheus setup
|
||||||
|
|
||||||
Add the following lines to Prometheus config file (it is usually located at `/etc/prometheus/prometheus.yml`):
|
Prometheus must be configured with [remote_write](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#remote_write)
|
||||||
|
in order to send data to VictoriaMetrics. Add the following lines
|
||||||
|
to Prometheus config file (it is usually located at `/etc/prometheus/prometheus.yml`):
|
||||||
|
|
||||||
```yml
|
```yml
|
||||||
remote_write:
|
remote_write:
|
||||||
- url: http://<victoriametrics-addr>:8428/api/v1/write
|
- url: http://<victoriametrics-addr>:8428/api/v1/write
|
||||||
queue_config:
|
|
||||||
max_samples_per_send: 10000
|
|
||||||
max_shards: 30
|
|
||||||
```
|
```
|
||||||
|
|
||||||
Substitute `<victoriametrics-addr>` with the hostname or IP address of VictoriaMetrics.
|
Substitute `<victoriametrics-addr>` with the hostname or IP address of VictoriaMetrics.
|
||||||
@ -165,6 +164,22 @@ This instructs Prometheus to add `datacenter=dc-123` label to each time series s
|
|||||||
The label name may be arbitrary - `datacenter` is just an example. The label value must be unique
|
The label name may be arbitrary - `datacenter` is just an example. The label value must be unique
|
||||||
across Prometheus instances, so those time series may be filtered and grouped by this label.
|
across Prometheus instances, so those time series may be filtered and grouped by this label.
|
||||||
|
|
||||||
|
For highly loaded Prometheus instances (400k+ samples per second)
|
||||||
|
the following tuning may be applied:
|
||||||
|
```
|
||||||
|
remote_write:
|
||||||
|
- url: http://<victoriametrics-addr>:8428/api/v1/write
|
||||||
|
queue_config:
|
||||||
|
max_samples_per_send: 10000
|
||||||
|
capacity: 20000
|
||||||
|
max_shards: 30
|
||||||
|
```
|
||||||
|
|
||||||
|
Using remote write increases memory usage for Prometheus up to ~25%
|
||||||
|
and depends on the shape of data. If you are experiencing issues with
|
||||||
|
too high memory consumption try to lower `max_samples_per_send`
|
||||||
|
and `capacity` params (keep in mind that these two params are tightly connected).
|
||||||
|
Read more about tuning remote write for Prometheus [here](https://prometheus.io/docs/practices/remote_write).
|
||||||
|
|
||||||
It is recommended upgrading Prometheus to [v2.12.0](https://github.com/prometheus/prometheus/releases) or newer,
|
It is recommended upgrading Prometheus to [v2.12.0](https://github.com/prometheus/prometheus/releases) or newer,
|
||||||
since the previous versions may have issues with `remote_write`.
|
since the previous versions may have issues with `remote_write`.
|
||||||
@ -547,6 +562,15 @@ Each JSON line would contain data for a single time series. An example output:
|
|||||||
Optional `start` and `end` args may be added to the request in order to limit the time frame for the exported data. These args may contain either
|
Optional `start` and `end` args may be added to the request in order to limit the time frame for the exported data. These args may contain either
|
||||||
unix timestamp in seconds or [RFC3339](https://www.ietf.org/rfc/rfc3339.txt) values.
|
unix timestamp in seconds or [RFC3339](https://www.ietf.org/rfc/rfc3339.txt) values.
|
||||||
|
|
||||||
|
Pass `Accept-Encoding: gzip` HTTP header in the request to `/api/v1/export` in order to reduce network bandwidth during exporing big amounts
|
||||||
|
of time series data. This enables gzip compression for the exported data. Example for exporting gzipped data:
|
||||||
|
|
||||||
|
```
|
||||||
|
curl -H 'Accept-Encoding: gzip' http://localhost:8428/api/v1/export -d 'match[]={__name__!=""}' > data.jsonl.gz
|
||||||
|
```
|
||||||
|
|
||||||
|
The maximum duration for each request to `/api/v1/export` is limited by `-search.maxExportDuration` command-line flag.
|
||||||
|
|
||||||
Exported data can be imported via POST'ing it to [/api/v1/import](#how-to-import-time-series-data).
|
Exported data can be imported via POST'ing it to [/api/v1/import](#how-to-import-time-series-data).
|
||||||
|
|
||||||
|
|
||||||
@ -565,10 +589,20 @@ The most efficient protocol for importing data into VictoriaMetrics is `/api/v1/
|
|||||||
|
|
||||||
```
|
```
|
||||||
# Export the data from <source-victoriametrics>:
|
# Export the data from <source-victoriametrics>:
|
||||||
curl -s 'http://source-victoriametrics:8428/api/v1/export' -d 'match={__name__!=""}' > exported_data.jsonl
|
curl http://source-victoriametrics:8428/api/v1/export -d 'match={__name__!=""}' > exported_data.jsonl
|
||||||
|
|
||||||
# Import the data to <destination-victoriametrics>:
|
# Import the data to <destination-victoriametrics>:
|
||||||
curl -X POST 'http://destination-victoriametrics:8428/api/v1/import' -T exported_data.jsonl
|
curl -X POST http://destination-victoriametrics:8428/api/v1/import -T exported_data.jsonl
|
||||||
|
```
|
||||||
|
|
||||||
|
Pass `Content-Encoding: gzip` HTTP request header to `/api/v1/import` for importing gzipped data:
|
||||||
|
|
||||||
|
```
|
||||||
|
# Export gzipped data from <source-victoriametrics>:
|
||||||
|
curl -H 'Accept-Encoding: gzip' http://source-victoriametrics:8428/api/v1/export -d 'match={__name__!=""}' > exported_data.jsonl.gz
|
||||||
|
|
||||||
|
# Import gzipped data to <destination-victoriametrics>:
|
||||||
|
curl -X POST -H 'Content-Encoding: gzip' http://destination-victoriametrics:8428/api/v1/import -T exported_data.jsonl.gz
|
||||||
```
|
```
|
||||||
|
|
||||||
Each request to `/api/v1/import` can load up to a single vCPU core on VictoriaMetrics. Import speed can be improved by splitting the original file into smaller parts
|
Each request to `/api/v1/import` can load up to a single vCPU core on VictoriaMetrics. Import speed can be improved by splitting the original file into smaller parts
|
||||||
@ -707,8 +741,10 @@ horizontally scalable long-term remote storage for really large Prometheus deplo
|
|||||||
|
|
||||||
### Alerting
|
### Alerting
|
||||||
|
|
||||||
VictoriaMetrics doesn't support rule evaluation and alerting yet, so these actions must be performed either
|
VictoriaMetrics doesn't support rule evaluation and alerting yet, so these actions can be performed at the following places:
|
||||||
on [Prometheus side](https://prometheus.io/docs/alerting/overview/) or on [Grafana side](https://grafana.com/docs/alerting/rules/).
|
* At Prometheus - see [the corresponding docs](https://prometheus.io/docs/alerting/overview/).
|
||||||
|
* At Promxy - see [the corresponding docs](https://github.com/jacksontj/promxy/blob/master/README.md#how-do-i-use-alertingrecording-rules-in-promxy).
|
||||||
|
* At Grafana - see [the corresponding docs](https://grafana.com/docs/alerting/rules/).
|
||||||
|
|
||||||
|
|
||||||
### Security
|
### Security
|
||||||
|
Loading…
Reference in New Issue
Block a user