From 835efb111e7ad9bbd9c1e86830cd12d590df05e1 Mon Sep 17 00:00:00 2001 From: Aliaksandr Valialkin Date: Wed, 1 Sep 2021 12:02:28 +0300 Subject: [PATCH] docs: `make docs-sync` --- docs/vmalert.md | 17 +++++- docs/vmctl.md | 147 ++++++++++++++++++++++++++++++++---------------- 2 files changed, 114 insertions(+), 50 deletions(-) diff --git a/docs/vmalert.md b/docs/vmalert.md index 5e2f51678..96e1d995a 100644 --- a/docs/vmalert.md +++ b/docs/vmalert.md @@ -315,6 +315,8 @@ to [/query_range](https://prometheus.io/docs/prometheus/latest/querying/api/#ran of the configured `-datasource.url`. Returned data then processed according to the rule type and backfilled to `-remoteWrite.url` via [Remote Write protocol](https://prometheus.io/docs/prometheus/latest/storage/#remote-storage-integrations). Vmalert respects `evaluationInterval` value set by flag or per-group during the replay. +Vmalert automatically disables caching on VictoriaMetrics side by sending `nocache=1` param. It allows +to prevent cache pollution and unwanted time range boundaries adjustment during backfilling. #### Recording rules @@ -351,6 +353,17 @@ See full description for these flags in `./vmalert --help`. * `query` template function is disabled for performance reasons (might be changed in future); +## Monitoring + +`vmalert` exports various metrics in Prometheus exposition format at `http://vmalert-host:8880/metrics` page. +We recommend setting up regular scraping of this page either through `vmagent` or by Prometheus so that the exported +metrics may be analyzed later. + +Use official [Grafana dashboard](https://grafana.com/grafana/dashboards/14950) for `vmalert` overview. +If you have suggestions for improvements or have found a bug - please open an issue on github or add +a review to the dashboard. + + ## Configuration Pass `-help` to `vmalert` in order to see the full list of supported @@ -516,9 +529,7 @@ The shortlist of configuration flags is the following: -remoteWrite.tlsServerName string Optional TLS server name to use for connections to -remoteWrite.url. By default the server name from -remoteWrite.url is used -remoteWrite.url string - Optional URL to VictoriaMetrics or vminsert where to persist alerts state and recording rules results in form of timeseries. For example, if -remoteWrite.url=http://127.0.0.1:8428 is specified, then the alerts state will be written to http://127.0.0.1:8428/api/v1/write . See also -remoteWrite.disablePathAppend - -remoteWrite.disablePathAppend - Whether to disable automatic appending of '/api/v1/write' path to the configured -remoteWrite.url. + Optional URL to VictoriaMetrics or vminsert where to persist alerts state and recording rules results in form of timeseries. For example, if -remoteWrite.url=http://127.0.0.1:8428 is specified, then the alerts state will be written to http://127.0.0.1:8428/api/v1/write . See also -remoteWrite.disablePathAppend -replay.maxDatapointsPerQuery int Max number of data points expected in one request. The higher the value, the less requests will be made during replay. (default 1000) -replay.ruleRetryAttempts int diff --git a/docs/vmctl.md b/docs/vmctl.md index 75316fd12..de96ea1cb 100644 --- a/docs/vmctl.md +++ b/docs/vmctl.md @@ -14,56 +14,63 @@ Features: - [x] OpenTSDB: migrate data from OpenTSDB to VictoriaMetrics - [ ] Storage Management: data re-balancing between nodes +vmctl acts as a proxy between data source ([Prometheus](#migrating-data-from-prometheus), +[InfluxDB](#migrating-data-from-influxdb-1x), [VictoriaMetrics](##migrating-data-from-victoriametrics), etc.) +and destination - VictoriaMetrics single or cluster version. To see the full list of supported modes +run the following command: +``` +./vmctl --help +NAME: + vmctl - VictoriaMetrics command-line tool + +USAGE: + vmctl [global options] command [command options] [arguments...] + +COMMANDS: + opentsdb Migrate timeseries from OpenTSDB + influx Migrate timeseries from InfluxDB + prometheus Migrate timeseries from Prometheus + vm-native Migrate time series between VictoriaMetrics installations via native binary format +``` + +Each mode has its own unique set of flags specific (e.g. prefixed with `influx` for influx mode) +to the data source and common list of flags for destination (prefixed with `vm` for VictoriaMetrics): +``` +./vmctl influx --help +OPTIONS: + --influx-addr value Influx server addr (default: "http://localhost:8086") + --influx-user value Influx user [$INFLUX_USERNAME] +... + --vm-addr vmctl VictoriaMetrics address to perform import requests. +Should be the same as --httpListenAddr value for single-node version or vminsert component. +When importing into the clustered version do not forget to set additionally --vm-account-id flag. +Please note, that vmctl performs initial readiness check for the given address by checking `/health` endpoint. (default: "http://localhost:8428") + --vm-user value VictoriaMetrics username for basic auth [$VM_USERNAME] + --vm-password value VictoriaMetrics password for basic auth [$VM_PASSWORD] +``` + +When doing a migration user needs to specify flags for source (where and how to fetch data) and for +destination (where to migrate data). Every mode has additional details and nuances, please see +them below in corresponding sections. + +For the destination flags see the full description by running the following command: +``` +./vmctl influx --help | grep vm- +``` + +Some flags like [--vm-extra-label](#adding-extra-labels) or [--vm-significant-figures](#significant-figures) +has additional sections with description below. Details about tweaking and adjusting settings +are explained in [Tuning](#tuning) section. + +Please note, that if you're going to import data into VictoriaMetrics cluster do not +forget to specify the `--vm-account-id` flag. See more details for cluster version +[here](https://github.com/VictoriaMetrics/VictoriaMetrics/tree/cluster). + ## Articles * [How to migrate data from Prometheus](https://medium.com/@romanhavronenko/victoriametrics-how-to-migrate-data-from-prometheus-d44a6728f043) * [How to migrate data from Prometheus. Filtering and modifying time series](https://medium.com/@romanhavronenko/victoriametrics-how-to-migrate-data-from-prometheus-filtering-and-modifying-time-series-6d40cea4bf21) -## How to build - -It is recommended using [binary releases](https://github.com/VictoriaMetrics/VictoriaMetrics/releases) - `vmctl` is located in `vmutils-*` archives there. - - -### Development build - -1. [Install Go](https://golang.org/doc/install). The minimum supported version is Go 1.16. -2. Run `make vmctl` from the root folder of [the repository](https://github.com/VictoriaMetrics/VictoriaMetrics). - It builds `vmctl` binary and puts it into the `bin` folder. - -### Production build - -1. [Install docker](https://docs.docker.com/install/). -2. Run `make vmctl-prod` from the root folder of [the repository](https://github.com/VictoriaMetrics/VictoriaMetrics). - It builds `vmctl-prod` binary and puts it into the `bin` folder. - -### Building docker images - -Run `make package-vmctl`. It builds `victoriametrics/vmctl:` docker image locally. -`` is auto-generated image tag, which depends on source code in the repository. -The `` may be manually set via `PKG_TAG=foobar make package-vmctl`. - -The base docker image is [alpine](https://hub.docker.com/_/alpine) but it is possible to use any other base image -by setting it via `` environment variable. For example, the following command builds the image on top of [scratch](https://hub.docker.com/_/scratch) image: - -```bash -ROOT_IMAGE=scratch make package-vmctl -``` - -### ARM build - -ARM build may run on Raspberry Pi or on [energy-efficient ARM servers](https://blog.cloudflare.com/arm-takes-wing/). - -#### Development ARM build - -1. [Install Go](https://golang.org/doc/install). The minimum supported version is Go 1.16. -2. Run `make vmctl-arm` or `make vmctl-arm64` from the root folder of [the repository](https://github.com/VictoriaMetrics/VictoriaMetrics). - It builds `vmctl-arm` or `vmctl-arm64` binary respectively and puts it into the `bin` folder. - -#### Production ARM build - -1. [Install docker](https://docs.docker.com/install/). -2. Run `make vmctl-arm-prod` or `make vmctl-arm64-prod` from the root folder of [the repository](https://github.com/VictoriaMetrics/VictoriaMetrics). - It builds `vmctl-arm-prod` or `vmctl-arm64-prod` binary respectively and puts it into the `bin` folder. ## Migrating data from OpenTSDB @@ -476,7 +483,8 @@ To avoid such situation try to filter out VM process metrics via `--vm-native-fi [Backfilling tips](https://github.com/VictoriaMetrics/VictoriaMetrics#backfilling) section. 3. `vmctl` doesn't provide relabeling or other types of labels management in this mode. Instead, use [relabeling in VictoriaMetrics](https://github.com/VictoriaMetrics/vmctl/issues/4#issuecomment-683424375). - +4. When importing into cluster version it is additionally required to specify the `--vm-account-id` flag. +See more details for cluster version [here](https://github.com/VictoriaMetrics/VictoriaMetrics/tree/cluster). ## Tuning @@ -555,4 +563,49 @@ results such as `average`, `rate`, etc. `vmctl` allows to add extra labels to all imported series. It can be achived with flag `--vm-extra-label label=value`. If multiple labels needs to be added, set flag for each label, for example, `--vm-extra-label label1=value1 --vm-extra-label label2=value2`. If timeseries already have label, that must be added with `--vm-extra-label` flag, flag has priority and will override label value from timeseries. - + +## How to build + +It is recommended using [binary releases](https://github.com/VictoriaMetrics/VictoriaMetrics/releases) - `vmctl` is located in `vmutils-*` archives there. + + +### Development build + +1. [Install Go](https://golang.org/doc/install). The minimum supported version is Go 1.16. +2. Run `make vmctl` from the root folder of [the repository](https://github.com/VictoriaMetrics/VictoriaMetrics). + It builds `vmctl` binary and puts it into the `bin` folder. + +### Production build + +1. [Install docker](https://docs.docker.com/install/). +2. Run `make vmctl-prod` from the root folder of [the repository](https://github.com/VictoriaMetrics/VictoriaMetrics). + It builds `vmctl-prod` binary and puts it into the `bin` folder. + +### Building docker images + +Run `make package-vmctl`. It builds `victoriametrics/vmctl:` docker image locally. +`` is auto-generated image tag, which depends on source code in the repository. +The `` may be manually set via `PKG_TAG=foobar make package-vmctl`. + +The base docker image is [alpine](https://hub.docker.com/_/alpine) but it is possible to use any other base image +by setting it via `` environment variable. For example, the following command builds the image on top of [scratch](https://hub.docker.com/_/scratch) image: + +```bash +ROOT_IMAGE=scratch make package-vmctl +``` + +### ARM build + +ARM build may run on Raspberry Pi or on [energy-efficient ARM servers](https://blog.cloudflare.com/arm-takes-wing/). + +#### Development ARM build + +1. [Install Go](https://golang.org/doc/install). The minimum supported version is Go 1.16. +2. Run `make vmctl-arm` or `make vmctl-arm64` from the root folder of [the repository](https://github.com/VictoriaMetrics/VictoriaMetrics). + It builds `vmctl-arm` or `vmctl-arm64` binary respectively and puts it into the `bin` folder. + +#### Production ARM build + +1. [Install docker](https://docs.docker.com/install/). +2. Run `make vmctl-arm-prod` or `make vmctl-arm64-prod` from the root folder of [the repository](https://github.com/VictoriaMetrics/VictoriaMetrics). + It builds `vmctl-arm-prod` or `vmctl-arm64-prod` binary respectively and puts it into the `bin` folder.