mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-22 08:10:44 +01:00
docs/Single-server-VictoriaMetrics.md: sync with README.md
This commit is contained in:
parent
45d21d18a8
commit
6282b29a44
@ -7,7 +7,6 @@ in [source code](https://github.com/VictoriaMetrics/VictoriaMetrics). Just downl
|
|||||||
|
|
||||||
Cluster version is available [here](https://github.com/VictoriaMetrics/VictoriaMetrics/tree/cluster).
|
Cluster version is available [here](https://github.com/VictoriaMetrics/VictoriaMetrics/tree/cluster).
|
||||||
|
|
||||||
|
|
||||||
## Case studies and talks
|
## Case studies and talks
|
||||||
|
|
||||||
* [Adidas](https://github.com/VictoriaMetrics/VictoriaMetrics/wiki/CaseStudies#adidas)
|
* [Adidas](https://github.com/VictoriaMetrics/VictoriaMetrics/wiki/CaseStudies#adidas)
|
||||||
@ -16,7 +15,6 @@ Cluster version is available [here](https://github.com/VictoriaMetrics/VictoriaM
|
|||||||
* [Wedos.com](https://github.com/VictoriaMetrics/VictoriaMetrics/wiki/CaseStudies#wedoscom)
|
* [Wedos.com](https://github.com/VictoriaMetrics/VictoriaMetrics/wiki/CaseStudies#wedoscom)
|
||||||
* [Dreamteam](https://github.com/VictoriaMetrics/VictoriaMetrics/wiki/CaseStudies#dreamteam)
|
* [Dreamteam](https://github.com/VictoriaMetrics/VictoriaMetrics/wiki/CaseStudies#dreamteam)
|
||||||
|
|
||||||
|
|
||||||
## Prominent features
|
## Prominent features
|
||||||
|
|
||||||
* Supports [Prometheus querying API](https://prometheus.io/docs/prometheus/latest/querying/api/), so it can be used as Prometheus drop-in replacement in Grafana.
|
* Supports [Prometheus querying API](https://prometheus.io/docs/prometheus/latest/querying/api/), so it can be used as Prometheus drop-in replacement in Grafana.
|
||||||
@ -43,9 +41,11 @@ Cluster version is available [here](https://github.com/VictoriaMetrics/VictoriaM
|
|||||||
to S3 or GCS with [vmbackup](https://github.com/VictoriaMetrics/VictoriaMetrics/blob/master/app/vmbackup/README.md) / [vmrestore](https://github.com/VictoriaMetrics/VictoriaMetrics/blob/master/app/vmrestore/README.md).
|
to S3 or GCS with [vmbackup](https://github.com/VictoriaMetrics/VictoriaMetrics/blob/master/app/vmbackup/README.md) / [vmrestore](https://github.com/VictoriaMetrics/VictoriaMetrics/blob/master/app/vmrestore/README.md).
|
||||||
See [this article](https://medium.com/@valyala/speeding-up-backups-for-big-time-series-databases-533c1a927883) for more details.
|
See [this article](https://medium.com/@valyala/speeding-up-backups-for-big-time-series-databases-533c1a927883) for more details.
|
||||||
* Storage is protected from corruption on unclean shutdown (i.e. OOM, hardware reset or `kill -9`) thanks to [the storage architecture](https://medium.com/@valyala/how-victoriametrics-makes-instant-snapshots-for-multi-terabyte-time-series-data-e1f3fb0e0282).
|
* Storage is protected from corruption on unclean shutdown (i.e. OOM, hardware reset or `kill -9`) thanks to [the storage architecture](https://medium.com/@valyala/how-victoriametrics-makes-instant-snapshots-for-multi-terabyte-time-series-data-e1f3fb0e0282).
|
||||||
* Supports metrics' ingestion and [backfilling](#backfilling) via the following protocols:
|
* Supports metrics' scraping, ingestion and [backfilling](#backfilling) via the following protocols:
|
||||||
|
* [Metrics from Prometheus exporters](https://github.com/prometheus/docs/blob/master/content/docs/instrumenting/exposition_formats.md#text-based-format)
|
||||||
|
such as [node_exporter](https://github.com/prometheus/node_exporter). See [these docs](#how-to-scrape-prometheus-exporters-such-as-node-exporter) for details.
|
||||||
* [Prometheus remote write API](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#remote_write)
|
* [Prometheus remote write API](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#remote_write)
|
||||||
* [InfluxDB line protocol](#how-to-send-data-from-influxdb-compatible-agents-such-as-telegraf)
|
* [InfluxDB line protocol](#how-to-send-data-from-influxdb-compatible-agents-such-as-telegraf) over HTTP, TCP and UDP.
|
||||||
* [Graphite plaintext protocol](#how-to-send-data-from-graphite-compatible-agents-such-as-statsd) with [tags](https://graphite.readthedocs.io/en/latest/tags.html#carbon)
|
* [Graphite plaintext protocol](#how-to-send-data-from-graphite-compatible-agents-such-as-statsd) with [tags](https://graphite.readthedocs.io/en/latest/tags.html#carbon)
|
||||||
if `-graphiteListenAddr` is set.
|
if `-graphiteListenAddr` is set.
|
||||||
* [OpenTSDB put message](#sending-data-via-telnet-put-protocol) if `-opentsdbListenAddr` is set.
|
* [OpenTSDB put message](#sending-data-via-telnet-put-protocol) if `-opentsdbListenAddr` is set.
|
||||||
@ -54,62 +54,61 @@ Cluster version is available [here](https://github.com/VictoriaMetrics/VictoriaM
|
|||||||
* Ideally works with big amounts of time series data from Kubernetes, IoT sensors, connected cars, industrial telemetry, financial data and various Enterprise workloads.
|
* Ideally works with big amounts of time series data from Kubernetes, IoT sensors, connected cars, industrial telemetry, financial data and various Enterprise workloads.
|
||||||
* Has open source [cluster version](https://github.com/VictoriaMetrics/VictoriaMetrics/tree/cluster).
|
* Has open source [cluster version](https://github.com/VictoriaMetrics/VictoriaMetrics/tree/cluster).
|
||||||
|
|
||||||
|
|
||||||
## Operation
|
## Operation
|
||||||
|
|
||||||
|
|
||||||
### Table of contents
|
### Table of contents
|
||||||
|
|
||||||
- [How to start VictoriaMetrics](#how-to-start-victoriametrics)
|
* [How to start VictoriaMetrics](#how-to-start-victoriametrics)
|
||||||
- [Prometheus setup](#prometheus-setup)
|
* [Environment variables](#environment-variables)
|
||||||
- [Grafana setup](#grafana-setup)
|
* [Prometheus setup](#prometheus-setup)
|
||||||
- [How to upgrade VictoriaMetrics?](#how-to-upgrade-victoriametrics)
|
* [Grafana setup](#grafana-setup)
|
||||||
- [How to apply new config to VictoriaMetrics?](#how-to-apply-new-config-to-victoriametrics)
|
* [How to upgrade VictoriaMetrics](#how-to-upgrade-victoriametrics)
|
||||||
- [How to send data from InfluxDB-compatible agents such as Telegraf?](#how-to-send-data-from-influxdb-compatible-agents-such-as-telegraf)
|
* [How to apply new config to VictoriaMetrics](#how-to-apply-new-config-to-victoriametrics)
|
||||||
- [How to send data from Graphite-compatible agents such as StatsD?](#how-to-send-data-from-graphite-compatible-agents-such-as-statsd)
|
* [How to scrape Prometheus exporters such as node_exporter](#how-to-scrape-prometheus-exporters-such-as-node-exporter)
|
||||||
- [Querying Graphite data](#querying-graphite-data)
|
* [How to send data from InfluxDB-compatible agents such as Telegraf](#how-to-send-data-from-influxdb-compatible-agents-such-as-telegraf)
|
||||||
- [How to send data from OpenTSDB-compatible agents?](#how-to-send-data-from-opentsdb-compatible-agents)
|
* [How to send data from Graphite-compatible agents such as StatsD](#how-to-send-data-from-graphite-compatible-agents-such-as-statsd)
|
||||||
- [Prometheus querying API usage](#prometheus-querying-api-usage)
|
* [Querying Graphite data](#querying-graphite-data)
|
||||||
- [How to build from sources](#how-to-build-from-sources)
|
* [How to send data from OpenTSDB-compatible agents](#how-to-send-data-from-opentsdb-compatible-agents)
|
||||||
- [Development build](#development-build)
|
* [Prometheus querying API usage](#prometheus-querying-api-usage)
|
||||||
- [Production build](#production-build)
|
* [How to build from sources](#how-to-build-from-sources)
|
||||||
- [ARM build](#arm-build)
|
* [Development build](#development-build)
|
||||||
- [Pure Go build (CGO_ENABLED=0)](#pure-go-build-cgo_enabled0)
|
* [Production build](#production-build)
|
||||||
- [Building docker images](#building-docker-images)
|
* [ARM build](#arm-build)
|
||||||
- [Start with docker-compose](#start-with-docker-compose)
|
* [Pure Go build (CGO_ENABLED=0)](#pure-go-build-cgo_enabled0)
|
||||||
- [Setting up service](#setting-up-service)
|
* [Building docker images](#building-docker-images)
|
||||||
- [How to work with snapshots?](#how-to-work-with-snapshots)
|
* [Start with docker-compose](#start-with-docker-compose)
|
||||||
- [How to delete time series?](#how-to-delete-time-series)
|
* [Setting up service](#setting-up-service)
|
||||||
- [How to export time series?](#how-to-export-time-series)
|
* [How to work with snapshots](#how-to-work-with-snapshots)
|
||||||
- [How to import time series data?](#how-to-import-time-series-data)
|
* [How to delete time series](#how-to-delete-time-series)
|
||||||
- [Federation](#federation)
|
* [How to export time series](#how-to-export-time-series)
|
||||||
- [Capacity planning](#capacity-planning)
|
* [How to import time series data](#how-to-import-time-series-data)
|
||||||
- [High availability](#high-availability)
|
* [Federation](#federation)
|
||||||
- [Deduplication](#deduplication)
|
* [Capacity planning](#capacity-planning)
|
||||||
- [Retention](#retention)
|
* [High availability](#high-availability)
|
||||||
- [Multiple retentions](#multiple-retentions)
|
* [Deduplication](#deduplication)
|
||||||
- [Downsampling](#downsampling)
|
* [Retention](#retention)
|
||||||
- [Multi-tenancy](#multi-tenancy)
|
* [Multiple retentions](#multiple-retentions)
|
||||||
- [Scalability and cluster version](#scalability-and-cluster-version)
|
* [Downsampling](#downsampling)
|
||||||
- [Alerting](#alerting)
|
* [Multi-tenancy](#multi-tenancy)
|
||||||
- [Security](#security)
|
* [Scalability and cluster version](#scalability-and-cluster-version)
|
||||||
- [Tuning](#tuning)
|
* [Alerting](#alerting)
|
||||||
- [Monitoring](#monitoring)
|
* [Security](#security)
|
||||||
- [Troubleshooting](#troubleshooting)
|
* [Tuning](#tuning)
|
||||||
- [Backfilling](#backfilling)
|
* [Monitoring](#monitoring)
|
||||||
- [Profiling](#profiling)
|
* [Troubleshooting](#troubleshooting)
|
||||||
- [Integrations](#integrations)
|
* [Backfilling](#backfilling)
|
||||||
- [Roadmap](#roadmap)
|
* [Profiling](#profiling)
|
||||||
- [Contacts](#contacts)
|
* [Integrations](#integrations)
|
||||||
- [Community and contributions](#community-and-contributions)
|
* [Roadmap](#roadmap)
|
||||||
- [Third-party contributions](#third-party-contributions)
|
* [Contacts](#contacts)
|
||||||
- [Reporting bugs](#reporting-bugs)
|
* [Community and contributions](#community-and-contributions)
|
||||||
- [Victoria Metrics Logo](#victoria-metrics-logo)
|
* [Third-party contributions](#third-party-contributions)
|
||||||
- [Logo Usage Guidelines](#logo-usage-guidelines)
|
* [Reporting bugs](#reporting-bugs)
|
||||||
- [Font used:](#font-used)
|
* [Victoria Metrics Logo](#victoria-metrics-logo)
|
||||||
- [Color Palette:](#color-palette)
|
* [Logo Usage Guidelines](#logo-usage-guidelines)
|
||||||
- [We kindly ask:](#we-kindly-ask)
|
* [Font used](#font-used)
|
||||||
|
* [Color Palette](#color-palette)
|
||||||
|
* [We kindly ask](#we-kindly-ask)
|
||||||
|
|
||||||
### How to start VictoriaMetrics
|
### How to start VictoriaMetrics
|
||||||
|
|
||||||
@ -124,11 +123,15 @@ The following command-line flags are used the most:
|
|||||||
|
|
||||||
Pass `-help` to see all the available flags with description and default values.
|
Pass `-help` to see all the available flags with description and default values.
|
||||||
|
|
||||||
Default flag values may be read from environment variables if `-envflag.enable` command-line flag is set.
|
|
||||||
See [this feature request](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/311) for more details.
|
|
||||||
|
|
||||||
It is recommended setting up [monitoring](#monitoring) for VictoriaMetrics.
|
It is recommended setting up [monitoring](#monitoring) for VictoriaMetrics.
|
||||||
|
|
||||||
|
#### Environment variables
|
||||||
|
|
||||||
|
Each flag values can be set thru environment variables by following these rules:
|
||||||
|
|
||||||
|
* The `-envflag.enable` flag must be set
|
||||||
|
* Each `.` in flag names must be substituted by `_` (for example `-insert.maxQueueDuration <duration>` will translate to `insert_maxQueueDuration=<duration>`)
|
||||||
|
* For repeating flags, an alternative syntax can be used by joining the different values into one using `,` as separator (for example `-storageNode <nodeA> -storageNode <nodeB>` will translate to `storageNode=<nodeA>,<nodeB>`)
|
||||||
|
|
||||||
### Prometheus setup
|
### Prometheus setup
|
||||||
|
|
||||||
@ -144,7 +147,7 @@ remote_write:
|
|||||||
Substitute `<victoriametrics-addr>` with the hostname or IP address of VictoriaMetrics.
|
Substitute `<victoriametrics-addr>` with the hostname or IP address of VictoriaMetrics.
|
||||||
Then apply the new config via the following command:
|
Then apply the new config via the following command:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
kill -HUP `pidof prometheus`
|
kill -HUP `pidof prometheus`
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -167,7 +170,8 @@ across Prometheus instances, so those time series may be filtered and grouped by
|
|||||||
|
|
||||||
For highly loaded Prometheus instances (400k+ samples per second)
|
For highly loaded Prometheus instances (400k+ samples per second)
|
||||||
the following tuning may be applied:
|
the following tuning may be applied:
|
||||||
```
|
|
||||||
|
```yaml
|
||||||
remote_write:
|
remote_write:
|
||||||
- url: http://<victoriametrics-addr>:8428/api/v1/write
|
- url: http://<victoriametrics-addr>:8428/api/v1/write
|
||||||
queue_config:
|
queue_config:
|
||||||
@ -185,12 +189,11 @@ Read more about tuning remote write for Prometheus [here](https://prometheus.io/
|
|||||||
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`.
|
||||||
|
|
||||||
|
|
||||||
### Grafana setup
|
### Grafana setup
|
||||||
|
|
||||||
Create [Prometheus datasource](http://docs.grafana.org/features/datasources/prometheus/) in Grafana with the following Url:
|
Create [Prometheus datasource](http://docs.grafana.org/features/datasources/prometheus/) in Grafana with the following Url:
|
||||||
|
|
||||||
```
|
```url
|
||||||
http://<victoriametrics-addr>:8428
|
http://<victoriametrics-addr>:8428
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -199,8 +202,7 @@ Substitute `<victoriametrics-addr>` with the hostname or IP address of VictoriaM
|
|||||||
Then build graphs with the created datasource using [Prometheus query language](https://prometheus.io/docs/prometheus/latest/querying/basics/).
|
Then build graphs with the created datasource using [Prometheus query language](https://prometheus.io/docs/prometheus/latest/querying/basics/).
|
||||||
VictoriaMetrics supports native PromQL and [extends it with useful features](https://github.com/VictoriaMetrics/VictoriaMetrics/wiki/MetricsQL).
|
VictoriaMetrics supports native PromQL and [extends it with useful features](https://github.com/VictoriaMetrics/VictoriaMetrics/wiki/MetricsQL).
|
||||||
|
|
||||||
|
### How to upgrade VictoriaMetrics
|
||||||
### How to upgrade VictoriaMetrics?
|
|
||||||
|
|
||||||
It is safe upgrading VictoriaMetrics to new versions unless [release notes](https://github.com/VictoriaMetrics/VictoriaMetrics/releases)
|
It is safe upgrading VictoriaMetrics to new versions unless [release notes](https://github.com/VictoriaMetrics/VictoriaMetrics/releases)
|
||||||
say otherwise. It is recommended performing regular upgrades to the latest version,
|
say otherwise. It is recommended performing regular upgrades to the latest version,
|
||||||
@ -215,8 +217,7 @@ Follow the following steps during the upgrade:
|
|||||||
Prometheus doesn't drop data during VictoriaMetrics restart.
|
Prometheus doesn't drop data during VictoriaMetrics restart.
|
||||||
See [this article](https://grafana.com/blog/2019/03/25/whats-new-in-prometheus-2.8-wal-based-remote-write/) for details.
|
See [this article](https://grafana.com/blog/2019/03/25/whats-new-in-prometheus-2.8-wal-based-remote-write/) for details.
|
||||||
|
|
||||||
|
### How to apply new config to VictoriaMetrics
|
||||||
### How to apply new config to VictoriaMetrics?
|
|
||||||
|
|
||||||
VictoriaMetrics must be restarted for applying new config:
|
VictoriaMetrics must be restarted for applying new config:
|
||||||
|
|
||||||
@ -227,20 +228,35 @@ VictoriaMetrics must be restarted for applying new config:
|
|||||||
Prometheus doesn't drop data during VictoriaMetrics restart.
|
Prometheus doesn't drop data during VictoriaMetrics restart.
|
||||||
See [this article](https://grafana.com/blog/2019/03/25/whats-new-in-prometheus-2.8-wal-based-remote-write/) for details.
|
See [this article](https://grafana.com/blog/2019/03/25/whats-new-in-prometheus-2.8-wal-based-remote-write/) for details.
|
||||||
|
|
||||||
|
### How to scrape Prometheus exporters such as [node-exporter](https://github.com/prometheus/node_exporter)
|
||||||
|
|
||||||
### How to send data from InfluxDB-compatible agents such as [Telegraf](https://www.influxdata.com/time-series-platform/telegraf/)?
|
VictoriaMetrics can be used as drop-in replacement for Prometheus for scraping targets configured in `prometheus.yml` config file according to [the specification](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#configuration-file).
|
||||||
|
Just set `-promscrape.config` command-line flag to the path to `prometheus.yml` config - and VictoriaMetrics should start scraping the configured targets.
|
||||||
|
Currently the following [scrape_config](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#scrape_config) types are supported:
|
||||||
|
|
||||||
|
* [static_config](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#static_config)
|
||||||
|
* [file_sd_config](https://prometheus.io/docs/prometheus/latest/configuration/configuration/#file_sd_config)
|
||||||
|
|
||||||
|
In the future other `*_sd_config` types will be supported.
|
||||||
|
|
||||||
|
See also [vmagent](https://github.com/VictoriaMetrics/VictoriaMetrics/blob/master/app/vmagent/README.md), which can be used as drop-in replacement for Prometheus.
|
||||||
|
|
||||||
|
### How to send data from InfluxDB-compatible agents such as [Telegraf](https://www.influxdata.com/time-series-platform/telegraf/)
|
||||||
|
|
||||||
Just use `http://<victoriametric-addr>:8428` url instead of InfluxDB url in agents' configs.
|
Just use `http://<victoriametric-addr>:8428` url instead of InfluxDB url in agents' configs.
|
||||||
For instance, put the following lines into `Telegraf` config, so it sends data to VictoriaMetrics instead of InfluxDB:
|
For instance, put the following lines into `Telegraf` config, so it sends data to VictoriaMetrics instead of InfluxDB:
|
||||||
|
|
||||||
```
|
```toml
|
||||||
[[outputs.influxdb]]
|
[[outputs.influxdb]]
|
||||||
urls = ["http://<victoriametrics-addr>:8428"]
|
urls = ["http://<victoriametrics-addr>:8428"]
|
||||||
```
|
```
|
||||||
|
|
||||||
Do not forget substituting `<victoriametrics-addr>` with the real address where VictoriaMetrics runs.
|
Do not forget substituting `<victoriametrics-addr>` with the real address where VictoriaMetrics runs.
|
||||||
|
|
||||||
|
Another option is to enable TCP and UDP receiver for Influx line protocol via `-influxListenAddr` command-line flag.
|
||||||
|
|
||||||
VictoriaMetrics maps Influx data using the following rules:
|
VictoriaMetrics maps Influx data using the following rules:
|
||||||
|
|
||||||
* [`db` query arg](https://docs.influxdata.com/influxdb/v1.7/tools/api/#write-http-endpoint) is mapped into `db` label value
|
* [`db` query arg](https://docs.influxdata.com/influxdb/v1.7/tools/api/#write-http-endpoint) is mapped into `db` label value
|
||||||
unless `db` tag exists in the Influx line.
|
unless `db` tag exists in the Influx line.
|
||||||
* Field names are mapped to time series names prefixed with `{measurement}{separator}` value,
|
* Field names are mapped to time series names prefixed with `{measurement}{separator}` value,
|
||||||
@ -251,13 +267,13 @@ VictoriaMetrics maps Influx data using the following rules:
|
|||||||
|
|
||||||
For example, the following Influx line:
|
For example, the following Influx line:
|
||||||
|
|
||||||
```
|
```raw
|
||||||
foo,tag1=value1,tag2=value2 field1=12,field2=40
|
foo,tag1=value1,tag2=value2 field1=12,field2=40
|
||||||
```
|
```
|
||||||
|
|
||||||
is converted into the following Prometheus data points:
|
is converted into the following Prometheus data points:
|
||||||
|
|
||||||
```
|
```raw
|
||||||
foo_field1{tag1="value1", tag2="value2"} 12
|
foo_field1{tag1="value1", tag2="value2"} 12
|
||||||
foo_field2{tag1="value1", tag2="value2"} 40
|
foo_field2{tag1="value1", tag2="value2"} 40
|
||||||
```
|
```
|
||||||
@ -265,20 +281,20 @@ foo_field2{tag1="value1", tag2="value2"} 40
|
|||||||
Example for writing data with [Influx line protocol](https://docs.influxdata.com/influxdb/v1.7/write_protocols/line_protocol_tutorial/)
|
Example for writing data with [Influx line protocol](https://docs.influxdata.com/influxdb/v1.7/write_protocols/line_protocol_tutorial/)
|
||||||
to local VictoriaMetrics using `curl`:
|
to local VictoriaMetrics using `curl`:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
curl -d 'measurement,tag1=value1,tag2=value2 field1=123,field2=1.23' -X POST 'http://localhost:8428/write'
|
curl -d 'measurement,tag1=value1,tag2=value2 field1=123,field2=1.23' -X POST 'http://localhost:8428/write'
|
||||||
```
|
```
|
||||||
|
|
||||||
An arbitrary number of lines delimited by '\n' may be sent in a single request.
|
An arbitrary number of lines delimited by '\n' may be sent in a single request.
|
||||||
After that the data may be read via [/api/v1/export](#how-to-export-time-series) endpoint:
|
After that the data may be read via [/api/v1/export](#how-to-export-time-series) endpoint:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
curl -G 'http://localhost:8428/api/v1/export' -d 'match={__name__=~"measurement_.*"}'
|
curl -G 'http://localhost:8428/api/v1/export' -d 'match={__name__=~"measurement_.*"}'
|
||||||
```
|
```
|
||||||
|
|
||||||
The `/api/v1/export` endpoint should return the following response:
|
The `/api/v1/export` endpoint should return the following response:
|
||||||
|
|
||||||
```
|
```jsonl
|
||||||
{"metric":{"__name__":"measurement_field1","tag1":"value1","tag2":"value2"},"values":[123],"timestamps":[1560272508147]}
|
{"metric":{"__name__":"measurement_field1","tag1":"value1","tag2":"value2"},"values":[123],"timestamps":[1560272508147]}
|
||||||
{"metric":{"__name__":"measurement_field2","tag1":"value1","tag2":"value2"},"values":[1.23],"timestamps":[1560272508147]}
|
{"metric":{"__name__":"measurement_field2","tag1":"value1","tag2":"value2"},"values":[1.23],"timestamps":[1560272508147]}
|
||||||
```
|
```
|
||||||
@ -286,23 +302,21 @@ The `/api/v1/export` endpoint should return the following response:
|
|||||||
Note that Influx line protocol expects [timestamps in *nanoseconds* by default](https://docs.influxdata.com/influxdb/v1.7/write_protocols/line_protocol_tutorial/#timestamp),
|
Note that Influx line protocol expects [timestamps in *nanoseconds* by default](https://docs.influxdata.com/influxdb/v1.7/write_protocols/line_protocol_tutorial/#timestamp),
|
||||||
while VictoriaMetrics stores them with *milliseconds* precision.
|
while VictoriaMetrics stores them with *milliseconds* precision.
|
||||||
|
|
||||||
|
### How to send data from Graphite-compatible agents such as [StatsD](https://github.com/etsy/statsd)
|
||||||
### How to send data from Graphite-compatible agents such as [StatsD](https://github.com/etsy/statsd)?
|
|
||||||
|
|
||||||
1) Enable Graphite receiver in VictoriaMetrics by setting `-graphiteListenAddr` command line flag. For instance,
|
1) Enable Graphite receiver in VictoriaMetrics by setting `-graphiteListenAddr` command line flag. For instance,
|
||||||
the following command will enable Graphite receiver in VictoriaMetrics on TCP and UDP port `2003`:
|
the following command will enable Graphite receiver in VictoriaMetrics on TCP and UDP port `2003`:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
/path/to/victoria-metrics-prod -graphiteListenAddr=:2003
|
/path/to/victoria-metrics-prod -graphiteListenAddr=:2003
|
||||||
```
|
```
|
||||||
|
|
||||||
2) Use the configured address in Graphite-compatible agents. For instance, set `graphiteHost`
|
2) Use the configured address in Graphite-compatible agents. For instance, set `graphiteHost`
|
||||||
to the VictoriaMetrics host in `StatsD` configs.
|
to the VictoriaMetrics host in `StatsD` configs.
|
||||||
|
|
||||||
|
|
||||||
Example for writing data with Graphite plaintext protocol to local VictoriaMetrics using `nc`:
|
Example for writing data with Graphite plaintext protocol to local VictoriaMetrics using `nc`:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
echo "foo.bar.baz;tag1=value1;tag2=value2 123 `date +%s`" | nc -N localhost 2003
|
echo "foo.bar.baz;tag1=value1;tag2=value2 123 `date +%s`" | nc -N localhost 2003
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -310,26 +324,23 @@ VictoriaMetrics sets the current time if the timestamp is omitted.
|
|||||||
An arbitrary number of lines delimited by `\n` may be sent in one go.
|
An arbitrary number of lines delimited by `\n` may be sent in one go.
|
||||||
After that the data may be read via [/api/v1/export](#how-to-export-time-series) endpoint:
|
After that the data may be read via [/api/v1/export](#how-to-export-time-series) endpoint:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
curl -G 'http://localhost:8428/api/v1/export' -d 'match=foo.bar.baz'
|
curl -G 'http://localhost:8428/api/v1/export' -d 'match=foo.bar.baz'
|
||||||
```
|
```
|
||||||
|
|
||||||
The `/api/v1/export` endpoint should return the following response:
|
The `/api/v1/export` endpoint should return the following response:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
{"metric":{"__name__":"foo.bar.baz","tag1":"value1","tag2":"value2"},"values":[123],"timestamps":[1560277406000]}
|
{"metric":{"__name__":"foo.bar.baz","tag1":"value1","tag2":"value2"},"values":[123],"timestamps":[1560277406000]}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
### Querying Graphite data
|
### Querying Graphite data
|
||||||
|
|
||||||
Data sent to VictoriaMetrics via `Graphite plaintext protocol` may be read either via
|
Data sent to VictoriaMetrics via `Graphite plaintext protocol` may be read either via
|
||||||
[Prometheus querying API](#prometheus-querying-api-usage)
|
[Prometheus querying API](#prometheus-querying-api-usage)
|
||||||
or via [go-graphite/carbonapi](https://github.com/go-graphite/carbonapi/blob/master/cmd/carbonapi/carbonapi.example.prometheus.yaml).
|
or via [go-graphite/carbonapi](https://github.com/go-graphite/carbonapi/blob/master/cmd/carbonapi/carbonapi.example.prometheus.yaml).
|
||||||
|
|
||||||
|
### How to send data from OpenTSDB-compatible agents
|
||||||
|
|
||||||
### How to send data from OpenTSDB-compatible agents?
|
|
||||||
|
|
||||||
VictoriaMetrics supports [telnet put protocol](http://opentsdb.net/docs/build/html/api_telnet/put.html)
|
VictoriaMetrics supports [telnet put protocol](http://opentsdb.net/docs/build/html/api_telnet/put.html)
|
||||||
and [HTTP /api/put requests](http://opentsdb.net/docs/build/html/api_http/put.html) for ingesting OpenTSDB data.
|
and [HTTP /api/put requests](http://opentsdb.net/docs/build/html/api_http/put.html) for ingesting OpenTSDB data.
|
||||||
@ -339,39 +350,37 @@ and [HTTP /api/put requests](http://opentsdb.net/docs/build/html/api_http/put.ht
|
|||||||
1) Enable OpenTSDB receiver in VictoriaMetrics by setting `-opentsdbListenAddr` command line flag. For instance,
|
1) Enable OpenTSDB receiver in VictoriaMetrics by setting `-opentsdbListenAddr` command line flag. For instance,
|
||||||
the following command enables OpenTSDB receiver in VictoriaMetrics on TCP and UDP port `4242`:
|
the following command enables OpenTSDB receiver in VictoriaMetrics on TCP and UDP port `4242`:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
/path/to/victoria-metrics-prod -opentsdbListenAddr=:4242
|
/path/to/victoria-metrics-prod -opentsdbListenAddr=:4242
|
||||||
```
|
```
|
||||||
|
|
||||||
2) Send data to the given address from OpenTSDB-compatible agents.
|
2) Send data to the given address from OpenTSDB-compatible agents.
|
||||||
|
|
||||||
|
|
||||||
Example for writing data with OpenTSDB protocol to local VictoriaMetrics using `nc`:
|
Example for writing data with OpenTSDB protocol to local VictoriaMetrics using `nc`:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
echo "put foo.bar.baz `date +%s` 123 tag1=value1 tag2=value2" | nc -N localhost 4242
|
echo "put foo.bar.baz `date +%s` 123 tag1=value1 tag2=value2" | nc -N localhost 4242
|
||||||
```
|
```
|
||||||
|
|
||||||
An arbitrary number of lines delimited by `\n` may be sent in one go.
|
An arbitrary number of lines delimited by `\n` may be sent in one go.
|
||||||
After that the data may be read via [/api/v1/export](#how-to-export-time-series) endpoint:
|
After that the data may be read via [/api/v1/export](#how-to-export-time-series) endpoint:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
curl -G 'http://localhost:8428/api/v1/export' -d 'match=foo.bar.baz'
|
curl -G 'http://localhost:8428/api/v1/export' -d 'match=foo.bar.baz'
|
||||||
```
|
```
|
||||||
|
|
||||||
The `/api/v1/export` endpoint should return the following response:
|
The `/api/v1/export` endpoint should return the following response:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
{"metric":{"__name__":"foo.bar.baz","tag1":"value1","tag2":"value2"},"values":[123],"timestamps":[1560277292000]}
|
{"metric":{"__name__":"foo.bar.baz","tag1":"value1","tag2":"value2"},"values":[123],"timestamps":[1560277292000]}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
#### Sending OpenTSDB data via HTTP `/api/put` requests
|
#### Sending OpenTSDB data via HTTP `/api/put` requests
|
||||||
|
|
||||||
1) Enable HTTP server for OpenTSDB `/api/put` requests by setting `-opentsdbHTTPListenAddr` command line flag. For instance,
|
1) Enable HTTP server for OpenTSDB `/api/put` requests by setting `-opentsdbHTTPListenAddr` command line flag. For instance,
|
||||||
the following command enables OpenTSDB HTTP server on port `4242`:
|
the following command enables OpenTSDB HTTP server on port `4242`:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
/path/to/victoria-metrics-prod -opentsdbHTTPListenAddr=:4242
|
/path/to/victoria-metrics-prod -opentsdbHTTPListenAddr=:4242
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -379,31 +388,30 @@ the following command enables OpenTSDB HTTP server on port `4242`:
|
|||||||
|
|
||||||
Example for writing a single data point:
|
Example for writing a single data point:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
curl -H 'Content-Type: application/json' -d '{"metric":"x.y.z","value":45.34,"tags":{"t1":"v1","t2":"v2"}}' http://localhost:4242/api/put
|
curl -H 'Content-Type: application/json' -d '{"metric":"x.y.z","value":45.34,"tags":{"t1":"v1","t2":"v2"}}' http://localhost:4242/api/put
|
||||||
```
|
```
|
||||||
|
|
||||||
Example for writing multiple data points in a single request:
|
Example for writing multiple data points in a single request:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
curl -H 'Content-Type: application/json' -d '[{"metric":"foo","value":45.34},{"metric":"bar","value":43}]' http://localhost:4242/api/put
|
curl -H 'Content-Type: application/json' -d '[{"metric":"foo","value":45.34},{"metric":"bar","value":43}]' http://localhost:4242/api/put
|
||||||
```
|
```
|
||||||
|
|
||||||
After that the data may be read via [/api/v1/export](#how-to-export-time-series) endpoint:
|
After that the data may be read via [/api/v1/export](#how-to-export-time-series) endpoint:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
curl -G 'http://localhost:8428/api/v1/export' -d 'match[]=x.y.z' -d 'match[]=foo' -d 'match[]=bar'
|
curl -G 'http://localhost:8428/api/v1/export' -d 'match[]=x.y.z' -d 'match[]=foo' -d 'match[]=bar'
|
||||||
```
|
```
|
||||||
|
|
||||||
The `/api/v1/export` endpoint should return the following response:
|
The `/api/v1/export` endpoint should return the following response:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
{"metric":{"__name__":"foo"},"values":[45.34],"timestamps":[1566464846000]}
|
{"metric":{"__name__":"foo"},"values":[45.34],"timestamps":[1566464846000]}
|
||||||
{"metric":{"__name__":"bar"},"values":[43],"timestamps":[1566464846000]}
|
{"metric":{"__name__":"bar"},"values":[43],"timestamps":[1566464846000]}
|
||||||
{"metric":{"__name__":"x.y.z","t1":"v1","t2":"v2"},"values":[45.34],"timestamps":[1566464763000]}
|
{"metric":{"__name__":"x.y.z","t1":"v1","t2":"v2"},"values":[45.34],"timestamps":[1566464763000]}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
### Prometheus querying API usage
|
### Prometheus querying API usage
|
||||||
|
|
||||||
VictoriaMetrics supports the following handlers from [Prometheus querying API](https://prometheus.io/docs/prometheus/latest/querying/api/):
|
VictoriaMetrics supports the following handlers from [Prometheus querying API](https://prometheus.io/docs/prometheus/latest/querying/api/):
|
||||||
@ -428,7 +436,6 @@ Additionally VictoriaMetrics provides the following handlers:
|
|||||||
so it can be slow if the database contains tens of millions of time series.
|
so it can be slow if the database contains tens of millions of time series.
|
||||||
* `/api/v1/labels/count` - it returns a list of `label: values_count` entries. It can be used for determining labels with the maximum number of values.
|
* `/api/v1/labels/count` - it returns a list of `label: values_count` entries. It can be used for determining labels with the maximum number of values.
|
||||||
|
|
||||||
|
|
||||||
### How to build from sources
|
### How to build from sources
|
||||||
|
|
||||||
We recommend using either [binary releases](https://github.com/VictoriaMetrics/VictoriaMetrics/releases) or
|
We recommend using either [binary releases](https://github.com/VictoriaMetrics/VictoriaMetrics/releases) or
|
||||||
@ -436,7 +443,6 @@ We recommend using either [binary releases](https://github.com/VictoriaMetrics/V
|
|||||||
from sources. Building from sources is reasonable when developing additional features specific
|
from sources. Building from sources is reasonable when developing additional features specific
|
||||||
to your needs.
|
to your needs.
|
||||||
|
|
||||||
|
|
||||||
#### Development build
|
#### Development build
|
||||||
|
|
||||||
1. [Install Go](https://golang.org/doc/install). The minimum supported version is Go 1.12.
|
1. [Install Go](https://golang.org/doc/install). The minimum supported version is Go 1.12.
|
||||||
@ -481,27 +487,24 @@ Run `make package-victoria-metrics`. It builds `victoriametrics/victoria-metrics
|
|||||||
`<PKG_TAG>` is auto-generated image tag, which depends on source code in the repository.
|
`<PKG_TAG>` is auto-generated image tag, which depends on source code in the repository.
|
||||||
The `<PKG_TAG>` may be manually set via `PKG_TAG=foobar make package-victoria-metrics`.
|
The `<PKG_TAG>` may be manually set via `PKG_TAG=foobar make package-victoria-metrics`.
|
||||||
|
|
||||||
|
|
||||||
### Start with docker-compose
|
### Start with docker-compose
|
||||||
|
|
||||||
[Docker-compose](https://github.com/VictoriaMetrics/VictoriaMetrics/blob/master/deployment/docker/docker-compose.yml)
|
[Docker-compose](https://github.com/VictoriaMetrics/VictoriaMetrics/blob/master/deployment/docker/docker-compose.yml)
|
||||||
helps to spin up VictoriaMetrics, Prometheus and Grafana with one command.
|
helps to spin up VictoriaMetrics, Prometheus and Grafana with one command.
|
||||||
More details may be found [here](https://github.com/VictoriaMetrics/VictoriaMetrics/tree/master/deployment/docker#folder-contains-basic-images-and-tools-for-building-and-running-victoria-metrics-in-docker).
|
More details may be found [here](https://github.com/VictoriaMetrics/VictoriaMetrics/tree/master/deployment/docker#folder-contains-basic-images-and-tools-for-building-and-running-victoria-metrics-in-docker).
|
||||||
|
|
||||||
|
|
||||||
### Setting up service
|
### Setting up service
|
||||||
|
|
||||||
Read [these instructions](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/43) on how to set up VictoriaMetrics as a service in your OS.
|
Read [these instructions](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/43) on how to set up VictoriaMetrics as a service in your OS.
|
||||||
|
|
||||||
|
### How to work with snapshots
|
||||||
### How to work with snapshots?
|
|
||||||
|
|
||||||
VictoriaMetrics can create [instant snapshots](https://medium.com/@valyala/how-victoriametrics-makes-instant-snapshots-for-multi-terabyte-time-series-data-e1f3fb0e0282)
|
VictoriaMetrics can create [instant snapshots](https://medium.com/@valyala/how-victoriametrics-makes-instant-snapshots-for-multi-terabyte-time-series-data-e1f3fb0e0282)
|
||||||
for all the data stored under `-storageDataPath` directory.
|
for all the data stored under `-storageDataPath` directory.
|
||||||
Navigate to `http://<victoriametrics-addr>:8428/snapshot/create` in order to create an instant snapshot.
|
Navigate to `http://<victoriametrics-addr>:8428/snapshot/create` in order to create an instant snapshot.
|
||||||
The page will return the following JSON response:
|
The page will return the following JSON response:
|
||||||
|
|
||||||
```
|
```json
|
||||||
{"status":"ok","snapshot":"<snapshot-name>"}
|
{"status":"ok","snapshot":"<snapshot-name>"}
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -517,13 +520,13 @@ to delete `<snapshot-name>` snapshot.
|
|||||||
Navigate to `http://<victoriametrics-addr>:8428/snapshot/delete_all` in order to delete all the snapshots.
|
Navigate to `http://<victoriametrics-addr>:8428/snapshot/delete_all` in order to delete all the snapshots.
|
||||||
|
|
||||||
Steps for restoring from a snapshot:
|
Steps for restoring from a snapshot:
|
||||||
|
|
||||||
1. Stop VictoriaMetrics with `kill -INT`.
|
1. Stop VictoriaMetrics with `kill -INT`.
|
||||||
2. Restore snapshot contents from backup with [vmrestore](https://github.com/VictoriaMetrics/VictoriaMetrics/blob/master/app/vmrestore/README.md)
|
2. Restore snapshot contents from backup with [vmrestore](https://github.com/VictoriaMetrics/VictoriaMetrics/blob/master/app/vmrestore/README.md)
|
||||||
to the directory pointed by `-storageDataPath`.
|
to the directory pointed by `-storageDataPath`.
|
||||||
3. Start VictoriaMetrics.
|
3. Start VictoriaMetrics.
|
||||||
|
|
||||||
|
### How to delete time series
|
||||||
### How to delete time series?
|
|
||||||
|
|
||||||
Send a request to `http://<victoriametrics-addr>:8428/api/v1/admin/tsdb/delete_series?match[]=<timeseries_selector_for_delete>`,
|
Send a request to `http://<victoriametrics-addr>:8428/api/v1/admin/tsdb/delete_series?match[]=<timeseries_selector_for_delete>`,
|
||||||
where `<timeseries_selector_for_delete>` may contain any [time series selector](https://prometheus.io/docs/prometheus/latest/querying/basics/#time-series-selectors)
|
where `<timeseries_selector_for_delete>` may contain any [time series selector](https://prometheus.io/docs/prometheus/latest/querying/basics/#time-series-selectors)
|
||||||
@ -535,20 +538,19 @@ before actually deleting the metrics.
|
|||||||
|
|
||||||
The delete API is intended mainly for the following cases:
|
The delete API is intended mainly for the following cases:
|
||||||
|
|
||||||
- One-off deleting of accidentally written invalid (or undesired) time series.
|
* One-off deleting of accidentally written invalid (or undesired) time series.
|
||||||
- One-off deleting of user data due to [GDPR](https://en.wikipedia.org/wiki/General_Data_Protection_Regulation).
|
* One-off deleting of user data due to [GDPR](https://en.wikipedia.org/wiki/General_Data_Protection_Regulation).
|
||||||
|
|
||||||
It isn't recommended using delete API for the following cases, since it brings non-zero overhead:
|
It isn't recommended using delete API for the following cases, since it brings non-zero overhead:
|
||||||
|
|
||||||
- Regular cleanups for unneded data. Just prevent writing unneeded data into VictoriaMetrics.
|
* Regular cleanups for unneded data. Just prevent writing unneeded data into VictoriaMetrics.
|
||||||
See [this article](https://www.robustperception.io/relabelling-can-discard-targets-timeseries-and-alerts) for details.
|
See [this article](https://www.robustperception.io/relabelling-can-discard-targets-timeseries-and-alerts) for details.
|
||||||
- Reducing disk space usage by deleting unneded time series. This doesn't work as expected, since the deleted
|
* Reducing disk space usage by deleting unneded time series. This doesn't work as expected, since the deleted
|
||||||
time series occupy disk space until the next merge operation, which can never occur.
|
time series occupy disk space until the next merge operation, which can never occur.
|
||||||
|
|
||||||
It is better using `-retentionPeriod` command-line flag for efficient pruning of old data.
|
It is better using `-retentionPeriod` command-line flag for efficient pruning of old data.
|
||||||
|
|
||||||
|
### How to export time series
|
||||||
### How to export time series?
|
|
||||||
|
|
||||||
Send a request to `http://<victoriametrics-addr>:8428/api/v1/export?match[]=<timeseries_selector_for_export>`,
|
Send a request to `http://<victoriametrics-addr>:8428/api/v1/export?match[]=<timeseries_selector_for_export>`,
|
||||||
where `<timeseries_selector_for_export>` may contain any [time series selector](https://prometheus.io/docs/prometheus/latest/querying/basics/#time-series-selectors)
|
where `<timeseries_selector_for_export>` may contain any [time series selector](https://prometheus.io/docs/prometheus/latest/querying/basics/#time-series-selectors)
|
||||||
@ -556,7 +558,7 @@ for metrics to export. Use `{__name__!=""}` selector for fetching all the time s
|
|||||||
The response would contain all the data for the selected time series in [JSON streaming format](https://en.wikipedia.org/wiki/JSON_streaming#Line-delimited_JSON).
|
The response would contain all the data for the selected time series in [JSON streaming format](https://en.wikipedia.org/wiki/JSON_streaming#Line-delimited_JSON).
|
||||||
Each JSON line would contain data for a single time series. An example output:
|
Each JSON line would contain data for a single time series. An example output:
|
||||||
|
|
||||||
```
|
```jsonl
|
||||||
{"metric":{"__name__":"up","job":"node_exporter","instance":"localhost:9100"},"values":[0,0,0],"timestamps":[1549891472010,1549891487724,1549891503438]}
|
{"metric":{"__name__":"up","job":"node_exporter","instance":"localhost:9100"},"values":[0,0,0],"timestamps":[1549891472010,1549891487724,1549891503438]}
|
||||||
{"metric":{"__name__":"up","job":"prometheus","instance":"localhost:9090"},"values":[1,1,1],"timestamps":[1549891461511,1549891476511,1549891491511]}
|
{"metric":{"__name__":"up","job":"prometheus","instance":"localhost:9090"},"values":[1,1,1],"timestamps":[1549891461511,1549891476511,1549891491511]}
|
||||||
```
|
```
|
||||||
@ -567,7 +569,7 @@ unix timestamp in seconds or [RFC3339](https://www.ietf.org/rfc/rfc3339.txt) val
|
|||||||
Pass `Accept-Encoding: gzip` HTTP header in the request to `/api/v1/export` in order to reduce network bandwidth during exporing big amounts
|
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:
|
of time series data. This enables gzip compression for the exported data. Example for exporting gzipped data:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
curl -H 'Accept-Encoding: gzip' http://localhost:8428/api/v1/export -d 'match[]={__name__!=""}' > data.jsonl.gz
|
curl -H 'Accept-Encoding: gzip' http://localhost:8428/api/v1/export -d 'match[]={__name__!=""}' > data.jsonl.gz
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -575,8 +577,7 @@ The maximum duration for each request to `/api/v1/export` is limited by `-search
|
|||||||
|
|
||||||
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).
|
||||||
|
|
||||||
|
### How to import time series data
|
||||||
### How to import time series data?
|
|
||||||
|
|
||||||
Time series data can be imported via any supported ingestion protocol:
|
Time series data can be imported via any supported ingestion protocol:
|
||||||
|
|
||||||
@ -589,7 +590,7 @@ Time series data can be imported via any supported ingestion protocol:
|
|||||||
|
|
||||||
The most efficient protocol for importing data into VictoriaMetrics is `/api/v1/import`. Example for importing data obtained via `/api/v1/export`:
|
The most efficient protocol for importing data into VictoriaMetrics is `/api/v1/import`. Example for importing data obtained via `/api/v1/export`:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
# Export the data from <source-victoriametrics>:
|
# Export the data from <source-victoriametrics>:
|
||||||
curl 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
|
||||||
|
|
||||||
@ -599,7 +600,7 @@ curl -X POST http://destination-victoriametrics:8428/api/v1/import -T exported_d
|
|||||||
|
|
||||||
Pass `Content-Encoding: gzip` HTTP request header to `/api/v1/import` for importing gzipped data:
|
Pass `Content-Encoding: gzip` HTTP request header to `/api/v1/import` for importing gzipped data:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
# Export gzipped data from <source-victoriametrics>:
|
# 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
|
curl -H 'Accept-Encoding: gzip' http://source-victoriametrics:8428/api/v1/export -d 'match={__name__!=""}' > exported_data.jsonl.gz
|
||||||
|
|
||||||
@ -610,7 +611,6 @@ curl -X POST -H 'Content-Encoding: gzip' http://destination-victoriametrics:8428
|
|||||||
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
|
||||||
and importing them concurrently. Note that the original file must be split on newlines.
|
and importing them concurrently. Note that the original file must be split on newlines.
|
||||||
|
|
||||||
|
|
||||||
### Federation
|
### Federation
|
||||||
|
|
||||||
VictoriaMetrics exports [Prometheus-compatible federation data](https://prometheus.io/docs/prometheus/latest/federation/)
|
VictoriaMetrics exports [Prometheus-compatible federation data](https://prometheus.io/docs/prometheus/latest/federation/)
|
||||||
@ -622,7 +622,6 @@ on the interval `[now - max_lookback ... now]` is scraped for each time series.
|
|||||||
For instance, `/federate?match[]=up&max_lookback=1h` would return last points on the `[now - 1h ... now]` interval. This may be useful for time series federation
|
For instance, `/federate?match[]=up&max_lookback=1h` would return last points on the `[now - 1h ... now]` interval. This may be useful for time series federation
|
||||||
with scrape intervals exceeding `5m`.
|
with scrape intervals exceeding `5m`.
|
||||||
|
|
||||||
|
|
||||||
### Capacity planning
|
### Capacity planning
|
||||||
|
|
||||||
A rough estimation of the required resources for ingestion path:
|
A rough estimation of the required resources for ingestion path:
|
||||||
@ -650,7 +649,6 @@ A rough estimation of the required resources for ingestion path:
|
|||||||
The actual ingress bandwidth usage depends on the average number of labels per ingested metric and the average size
|
The actual ingress bandwidth usage depends on the average number of labels per ingested metric and the average size
|
||||||
of label values. The higher number of per-metric labels and longer label values mean the higher ingress bandwidth.
|
of label values. The higher number of per-metric labels and longer label values mean the higher ingress bandwidth.
|
||||||
|
|
||||||
|
|
||||||
The required resources for query path:
|
The required resources for query path:
|
||||||
|
|
||||||
* RAM size: depends on the number of time series to scan in each query and the `step`
|
* RAM size: depends on the number of time series to scan in each query and the `step`
|
||||||
@ -662,7 +660,6 @@ The required resources for query path:
|
|||||||
* Network usage: depends on the frequency and the type of incoming requests. Typical Grafana dashboards usually
|
* Network usage: depends on the frequency and the type of incoming requests. Typical Grafana dashboards usually
|
||||||
require negligible network bandwidth.
|
require negligible network bandwidth.
|
||||||
|
|
||||||
|
|
||||||
### High availability
|
### High availability
|
||||||
|
|
||||||
1) Install multiple VictoriaMetrics instances in distinct datacenters (availability zones).
|
1) Install multiple VictoriaMetrics instances in distinct datacenters (availability zones).
|
||||||
@ -681,7 +678,7 @@ remote_write:
|
|||||||
|
|
||||||
3) Apply the updated config:
|
3) Apply the updated config:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
kill -HUP `pidof prometheus`
|
kill -HUP `pidof prometheus`
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -689,14 +686,12 @@ kill -HUP `pidof prometheus`
|
|||||||
5) Set up [Promxy](https://github.com/jacksontj/promxy) in front of all the VictoriaMetrics replicas.
|
5) Set up [Promxy](https://github.com/jacksontj/promxy) in front of all the VictoriaMetrics replicas.
|
||||||
6) Set up Prometheus datasource in Grafana that points to Promxy.
|
6) Set up Prometheus datasource in Grafana that points to Promxy.
|
||||||
|
|
||||||
|
|
||||||
If you have Prometheus HA pairs with replicas `r1` and `r2` in each pair, then configure each `r1`
|
If you have Prometheus HA pairs with replicas `r1` and `r2` in each pair, then configure each `r1`
|
||||||
to write data to `victoriametrics-addr-1`, while each `r2` should write data to `victoriametrics-addr-2`.
|
to write data to `victoriametrics-addr-1`, while each `r2` should write data to `victoriametrics-addr-2`.
|
||||||
|
|
||||||
Another option is to write data simultaneously from Prometheus HA pair to a pair of VictoriaMetrics instances
|
Another option is to write data simultaneously from Prometheus HA pair to a pair of VictoriaMetrics instances
|
||||||
with the enabled de-duplication. See [this section](#deduplication) for details.
|
with the enabled de-duplication. See [this section](#deduplication) for details.
|
||||||
|
|
||||||
|
|
||||||
### Deduplication
|
### Deduplication
|
||||||
|
|
||||||
VictoriaMetrics de-duplicates data points if `-dedup.minScrapeInterval` command-line flag
|
VictoriaMetrics de-duplicates data points if `-dedup.minScrapeInterval` command-line flag
|
||||||
@ -706,7 +701,6 @@ The de-duplication reduces disk space usage if multiple identically configured P
|
|||||||
write data to the same VictoriaMetrics instance. Note that these Prometheus instances must have identical
|
write data to the same VictoriaMetrics instance. Note that these Prometheus instances must have identical
|
||||||
`external_labels` section in their configs, so they write data to the same time series.
|
`external_labels` section in their configs, so they write data to the same time series.
|
||||||
|
|
||||||
|
|
||||||
### Retention
|
### Retention
|
||||||
|
|
||||||
Retention is configured with `-retentionPeriod` command-line flag. For instance, `-retentionPeriod=3` means
|
Retention is configured with `-retentionPeriod` command-line flag. For instance, `-retentionPeriod=3` means
|
||||||
@ -716,7 +710,6 @@ Directories for months outside the configured retention are deleted on the first
|
|||||||
In order to keep data according to `-retentionPeriod` max disk space usage is going to be `-retentionPeriod` + 1 month.
|
In order to keep data according to `-retentionPeriod` max disk space usage is going to be `-retentionPeriod` + 1 month.
|
||||||
For example if `-retentionPeriod` is set to 1, data for January is deleted on March 1st.
|
For example if `-retentionPeriod` is set to 1, data for January is deleted on March 1st.
|
||||||
|
|
||||||
|
|
||||||
### Multiple retentions
|
### Multiple retentions
|
||||||
|
|
||||||
Just start multiple VictoriaMetrics instances with distinct values for the following flags:
|
Just start multiple VictoriaMetrics instances with distinct values for the following flags:
|
||||||
@ -725,24 +718,22 @@ Just start multiple VictoriaMetrics instances with distinct values for the follo
|
|||||||
* `-storageDataPath`, so the data for each retention period is saved in a separate directory
|
* `-storageDataPath`, so the data for each retention period is saved in a separate directory
|
||||||
* `-httpListenAddr`, so clients may reach VictoriaMetrics instance with proper retention
|
* `-httpListenAddr`, so clients may reach VictoriaMetrics instance with proper retention
|
||||||
|
|
||||||
|
|
||||||
### Downsampling
|
### Downsampling
|
||||||
|
|
||||||
There is no downsampling support at the moment, but:
|
There is no downsampling support at the moment, but:
|
||||||
- VictoriaMetrics is optimized for querying big amounts of raw data. See benchmark results for heavy queries
|
|
||||||
|
* VictoriaMetrics is optimized for querying big amounts of raw data. See benchmark results for heavy queries
|
||||||
in [this article](https://medium.com/@valyala/measuring-vertical-scalability-for-time-series-databases-in-google-cloud-92550d78d8ae).
|
in [this article](https://medium.com/@valyala/measuring-vertical-scalability-for-time-series-databases-in-google-cloud-92550d78d8ae).
|
||||||
- VictoriaMetrics has good compression for on-disk data. See [this article](https://medium.com/@valyala/victoriametrics-achieving-better-compression-for-time-series-data-than-gorilla-317bc1f95932)
|
* VictoriaMetrics has good compression for on-disk data. See [this article](https://medium.com/@valyala/victoriametrics-achieving-better-compression-for-time-series-data-than-gorilla-317bc1f95932)
|
||||||
for details.
|
for details.
|
||||||
|
|
||||||
These properties reduce the need of downsampling. We plan to implement downsampling in the future.
|
These properties reduce the need of downsampling. We plan to implement downsampling in the future.
|
||||||
See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/36) for details.
|
See [this issue](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/36) for details.
|
||||||
|
|
||||||
|
|
||||||
### Multi-tenancy
|
### Multi-tenancy
|
||||||
|
|
||||||
Single-node VictoriaMetrics doesn't support multi-tenancy. Use [cluster version](https://github.com/VictoriaMetrics/VictoriaMetrics/tree/cluster) instead.
|
Single-node VictoriaMetrics doesn't support multi-tenancy. Use [cluster version](https://github.com/VictoriaMetrics/VictoriaMetrics/tree/cluster) instead.
|
||||||
|
|
||||||
|
|
||||||
### Scalability and cluster version
|
### Scalability and cluster version
|
||||||
|
|
||||||
Though single-node VictoriaMetrics cannot scale to multiple nodes, it is optimized for resource usage - storage size / bandwidth / IOPS, RAM, CPU.
|
Though single-node VictoriaMetrics cannot scale to multiple nodes, it is optimized for resource usage - storage size / bandwidth / IOPS, RAM, CPU.
|
||||||
@ -753,15 +744,14 @@ So try single-node VictoriaMetrics at first and then [switch to cluster version]
|
|||||||
horizontally scalable long-term remote storage for really large Prometheus deployments.
|
horizontally scalable long-term remote storage for really large Prometheus deployments.
|
||||||
[Contact us](mailto:info@victoriametrics.com) for paid support.
|
[Contact us](mailto:info@victoriametrics.com) for paid support.
|
||||||
|
|
||||||
|
|
||||||
### Alerting
|
### Alerting
|
||||||
|
|
||||||
VictoriaMetrics doesn't support rule evaluation and alerting yet, so these actions can be performed at the following places:
|
VictoriaMetrics doesn't support rule evaluation and alerting yet, so these actions can be performed at the following places:
|
||||||
|
|
||||||
* At Prometheus - see [the corresponding docs](https://prometheus.io/docs/alerting/overview/).
|
* 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 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/).
|
* At Grafana - see [the corresponding docs](https://grafana.com/docs/alerting/rules/).
|
||||||
|
|
||||||
|
|
||||||
### Security
|
### Security
|
||||||
|
|
||||||
Do not forget protecting sensitive endpoints in VictoriaMetrics when exposing it to untrusted networks such as the internet.
|
Do not forget protecting sensitive endpoints in VictoriaMetrics when exposing it to untrusted networks such as the internet.
|
||||||
@ -776,7 +766,6 @@ Consider setting the following command-line flags:
|
|||||||
Explicitly set internal network interface for TCP and UDP ports for data ingestion with Graphite and OpenTSDB formats.
|
Explicitly set internal network interface for TCP and UDP ports for data ingestion with Graphite and OpenTSDB formats.
|
||||||
For example, substitute `-graphiteListenAddr=:2003` with `-graphiteListenAddr=<internal_iface_ip>:2003`.
|
For example, substitute `-graphiteListenAddr=:2003` with `-graphiteListenAddr=<internal_iface_ip>:2003`.
|
||||||
|
|
||||||
|
|
||||||
### Tuning
|
### Tuning
|
||||||
|
|
||||||
* There is no need for VictoriaMetrics tuning since it uses reasonable defaults for command-line flags,
|
* There is no need for VictoriaMetrics tuning since it uses reasonable defaults for command-line flags,
|
||||||
@ -789,15 +778,14 @@ For example, substitute `-graphiteListenAddr=:2003` with `-graphiteListenAddr=<i
|
|||||||
If you plan to store more than 1TB of data on `ext4` partition or plan extending it to more than 16TB,
|
If you plan to store more than 1TB of data on `ext4` partition or plan extending it to more than 16TB,
|
||||||
then the following options are recommended to pass to `mkfs.ext4`:
|
then the following options are recommended to pass to `mkfs.ext4`:
|
||||||
|
|
||||||
```
|
```bash
|
||||||
mkfs.ext4 ... -O 64bit,huge_file,extent -T huge
|
mkfs.ext4 ... -O 64bit,huge_file,extent -T huge
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
||||||
### Monitoring
|
### Monitoring
|
||||||
|
|
||||||
VictoriaMetrics exports internal metrics in Prometheus format at `/metrics` page.
|
VictoriaMetrics exports internal metrics in Prometheus format at `/metrics` page.
|
||||||
These metrics may be collected either via Prometheus by adding the corresponding scrape config to it.
|
These metrics may be collected via Prometheus by adding the corresponding scrape config to it.
|
||||||
Alternatively they can be self-scraped by setting `-selfScrapeInterval` command-line flag to duration greater than 0.
|
Alternatively they can be self-scraped by setting `-selfScrapeInterval` command-line flag to duration greater than 0.
|
||||||
For example, `-selfScrapeInterval=10s` would enable self-scraping of `/metrics` page with 10 seconds interval.
|
For example, `-selfScrapeInterval=10s` would enable self-scraping of `/metrics` page with 10 seconds interval.
|
||||||
|
|
||||||
@ -816,7 +804,6 @@ The most interesting metrics are:
|
|||||||
where `system_memory` is the amount of system memory and `-memory.allowedPercent` is the corresponding flag value.
|
where `system_memory` is the amount of system memory and `-memory.allowedPercent` is the corresponding flag value.
|
||||||
* `vm_rows_inserted_total` - the total number of inserted rows since VictoriaMetrics start.
|
* `vm_rows_inserted_total` - the total number of inserted rows since VictoriaMetrics start.
|
||||||
|
|
||||||
|
|
||||||
### Troubleshooting
|
### Troubleshooting
|
||||||
|
|
||||||
* It is recommended to use default command-line flag values (i.e. don't set them explicitly) until the need
|
* It is recommended to use default command-line flag values (i.e. don't set them explicitly) until the need
|
||||||
@ -838,6 +825,9 @@ The most interesting metrics are:
|
|||||||
of data loss stored in the broken parts. In the future, `vmrecover` tool will be created
|
of data loss stored in the broken parts. In the future, `vmrecover` tool will be created
|
||||||
for automatic recovering from such errors.
|
for automatic recovering from such errors.
|
||||||
|
|
||||||
|
* If you see gaps on the graphs, try resetting the cache by sending request to `/internal/resetRollupResultCache`.
|
||||||
|
If this removes gaps on the graphs, then it is likely data with timestamps older than `-search.cacheTimestampOffset`
|
||||||
|
is ingested into VictoriaMetrics. Make sure that data sources have synchronized time with VictoriaMetrics.
|
||||||
|
|
||||||
### Backfilling
|
### Backfilling
|
||||||
|
|
||||||
@ -848,18 +838,22 @@ It is recommended disabling query cache with `-search.disableCache` command-line
|
|||||||
historical data with timestamps from the past, since the cache assumes that the data is written with
|
historical data with timestamps from the past, since the cache assumes that the data is written with
|
||||||
the current timestamps. Query cache can be enabled after the backfilling is complete.
|
the current timestamps. Query cache can be enabled after the backfilling is complete.
|
||||||
|
|
||||||
|
An alternative solution is to query `/internal/resetRollupResultCache` url after backfilling is complete. This will reset
|
||||||
|
the query cache, which could contain incomplete data cached during the backfilling.
|
||||||
|
|
||||||
### Profiling
|
### Profiling
|
||||||
|
|
||||||
VictoriaMetrics provides handlers for collecting the following [Go profiles](https://blog.golang.org/profiling-go-programs):
|
VictoriaMetrics provides handlers for collecting the following [Go profiles](https://blog.golang.org/profiling-go-programs):
|
||||||
|
|
||||||
- Memory profile. It can be collected with the following command:
|
* Memory profile. It can be collected with the following command:
|
||||||
```
|
|
||||||
|
```bash
|
||||||
curl -s http://<victoria-metrics-host>:8428/debug/pprof/heap > mem.pprof
|
curl -s http://<victoria-metrics-host>:8428/debug/pprof/heap > mem.pprof
|
||||||
```
|
```
|
||||||
|
|
||||||
- CPU profile. It can be collected with the following command:
|
* CPU profile. It can be collected with the following command:
|
||||||
```
|
|
||||||
|
```bash
|
||||||
curl -s http://<victoria-metrics-host>:8428/debug/pprof/profile > cpu.pprof
|
curl -s http://<victoria-metrics-host>:8428/debug/pprof/profile > cpu.pprof
|
||||||
```
|
```
|
||||||
|
|
||||||
@ -867,7 +861,6 @@ The command for collecting CPU profile waits for 30 seconds before returning.
|
|||||||
|
|
||||||
The collected profiles may be analyzed with [go tool pprof](https://github.com/google/pprof).
|
The collected profiles may be analyzed with [go tool pprof](https://github.com/google/pprof).
|
||||||
|
|
||||||
|
|
||||||
## Integrations
|
## Integrations
|
||||||
|
|
||||||
* [netdata](https://github.com/netdata/netdata) can push data into VictoriaMetrics via `Prometheus remote_write API`.
|
* [netdata](https://github.com/netdata/netdata) can push data into VictoriaMetrics via `Prometheus remote_write API`.
|
||||||
@ -876,65 +869,57 @@ The collected profiles may be analyzed with [go tool pprof](https://github.com/g
|
|||||||
See [this example](/blob/master/cmd/carbonapi/carbonapi.example.prometheus.yaml).
|
See [this example](/blob/master/cmd/carbonapi/carbonapi.example.prometheus.yaml).
|
||||||
* [Ansible role for installing VictoriaMetrics](https://github.com/dreamteam-gg/ansible-victoriametrics-role).
|
* [Ansible role for installing VictoriaMetrics](https://github.com/dreamteam-gg/ansible-victoriametrics-role).
|
||||||
|
|
||||||
|
|
||||||
## Roadmap
|
## Roadmap
|
||||||
|
|
||||||
- [ ] Replication [#118](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/118)
|
* [ ] Replication [#118](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/118)
|
||||||
- [ ] Support of Object Storages (GCS, S3, Azure Storage) [#38](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/38)
|
* [ ] Support of Object Storages (GCS, S3, Azure Storage) [#38](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/38)
|
||||||
- [ ] Data downsampling [#36](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/36)
|
* [ ] Data downsampling [#36](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/36)
|
||||||
- [ ] Alert Manager Integration [#119](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/119)
|
* [ ] Alert Manager Integration [#119](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/119)
|
||||||
- [ ] CLI tool for data migration, re-balancing and adding/removing nodes [#103](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/103)
|
* [ ] CLI tool for data migration, re-balancing and adding/removing nodes [#103](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/103)
|
||||||
|
|
||||||
|
|
||||||
The discussion happens [here](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/129). Feel free to comment on any item or add you own one.
|
The discussion happens [here](https://github.com/VictoriaMetrics/VictoriaMetrics/issues/129). Feel free to comment on any item or add you own one.
|
||||||
|
|
||||||
|
|
||||||
## Contacts
|
## Contacts
|
||||||
|
|
||||||
Contact us with any questions regarding VictoriaMetrics at [info@victoriametrics.com](mailto:info@victoriametrics.com).
|
Contact us with any questions regarding VictoriaMetrics at [info@victoriametrics.com](mailto:info@victoriametrics.com).
|
||||||
|
|
||||||
|
|
||||||
## Community and contributions
|
## Community and contributions
|
||||||
|
|
||||||
Feel free asking any questions regarding VictoriaMetrics:
|
Feel free asking any questions regarding VictoriaMetrics:
|
||||||
|
|
||||||
- [slack](http://slack.victoriametrics.com/)
|
* [slack](http://slack.victoriametrics.com/)
|
||||||
- [reddit](https://www.reddit.com/r/VictoriaMetrics/)
|
* [reddit](https://www.reddit.com/r/VictoriaMetrics/)
|
||||||
- [telegram-en](https://t.me/VictoriaMetrics_en)
|
* [telegram-en](https://t.me/VictoriaMetrics_en)
|
||||||
- [telegram-ru](https://t.me/VictoriaMetrics_ru1)
|
* [telegram-ru](https://t.me/VictoriaMetrics_ru1)
|
||||||
- [google groups](https://groups.google.com/forum/#!forum/victorametrics-users)
|
* [google groups](https://groups.google.com/forum/#!forum/victorametrics-users)
|
||||||
|
|
||||||
|
|
||||||
If you like VictoriaMetrics and want to contribute, then we need the following:
|
If you like VictoriaMetrics and want to contribute, then we need the following:
|
||||||
|
|
||||||
- Filing issues and feature requests [here](https://github.com/VictoriaMetrics/VictoriaMetrics/issues).
|
* Filing issues and feature requests [here](https://github.com/VictoriaMetrics/VictoriaMetrics/issues).
|
||||||
- Spreading a word about VictoriaMetrics: conference talks, articles, comments, experience sharing with colleagues.
|
* Spreading a word about VictoriaMetrics: conference talks, articles, comments, experience sharing with colleagues.
|
||||||
- Updating documentation.
|
* Updating documentation.
|
||||||
|
|
||||||
We are open to third-party pull requests provided they follow [KISS design principle](https://en.wikipedia.org/wiki/KISS_principle):
|
We are open to third-party pull requests provided they follow [KISS design principle](https://en.wikipedia.org/wiki/KISS_principle):
|
||||||
|
|
||||||
- Prefer simple code and architecture.
|
* Prefer simple code and architecture.
|
||||||
- Avoid complex abstractions.
|
* Avoid complex abstractions.
|
||||||
- Avoid magic code and fancy algorithms.
|
* Avoid magic code and fancy algorithms.
|
||||||
- Avoid [big external dependencies](https://medium.com/@valyala/stripping-dependency-bloat-in-victoriametrics-docker-image-983fb5912b0d).
|
* Avoid [big external dependencies](https://medium.com/@valyala/stripping-dependency-bloat-in-victoriametrics-docker-image-983fb5912b0d).
|
||||||
- Minimize the number of moving parts in the distributed system.
|
* Minimize the number of moving parts in the distributed system.
|
||||||
- Avoid automated decisions, which may hurt cluster availability, consistency or performance.
|
* Avoid automated decisions, which may hurt cluster availability, consistency or performance.
|
||||||
|
|
||||||
Adhering `KISS` principle simplifies the resulting code and architecture, so it can be reviewed, understood and verified by many people.
|
Adhering `KISS` principle simplifies the resulting code and architecture, so it can be reviewed, understood and verified by many people.
|
||||||
|
|
||||||
|
|
||||||
## Third-party contributions
|
## Third-party contributions
|
||||||
|
|
||||||
* [Unofficial yum repository](https://copr.fedorainfracloud.org/coprs/antonpatsev/VictoriaMetrics/) ([source code](https://github.com/patsevanton/victoriametrics-rpm))
|
* [Unofficial yum repository](https://copr.fedorainfracloud.org/coprs/antonpatsev/VictoriaMetrics/) ([source code](https://github.com/patsevanton/victoriametrics-rpm))
|
||||||
* [Prometheus -> VictoriaMetrics exporter #1](https://github.com/ryotarai/prometheus-tsdb-dump)
|
* [Prometheus -> VictoriaMetrics exporter #1](https://github.com/ryotarai/prometheus-tsdb-dump)
|
||||||
* [Prometheus -> VictoriaMetrics exporter #2](https://github.com/AnchorFree/tsdb-remote-write)
|
* [Prometheus -> VictoriaMetrics exporter #2](https://github.com/AnchorFree/tsdb-remote-write)
|
||||||
|
|
||||||
|
|
||||||
## Reporting bugs
|
## Reporting bugs
|
||||||
|
|
||||||
Report bugs and propose new features [here](https://github.com/VictoriaMetrics/VictoriaMetrics/issues).
|
Report bugs and propose new features [here](https://github.com/VictoriaMetrics/VictoriaMetrics/issues).
|
||||||
|
|
||||||
|
|
||||||
## Victoria Metrics Logo
|
## Victoria Metrics Logo
|
||||||
|
|
||||||
[Zip](VM_logo.zip) contains three folders with different image orientations (main color and inverted version).
|
[Zip](VM_logo.zip) contains three folders with different image orientations (main color and inverted version).
|
||||||
@ -945,22 +930,21 @@ Files included in each folder:
|
|||||||
* 2 PNG Preview files with transparent background
|
* 2 PNG Preview files with transparent background
|
||||||
* 2 EPS Adobe Illustrator EPS10 files
|
* 2 EPS Adobe Illustrator EPS10 files
|
||||||
|
|
||||||
|
|
||||||
### Logo Usage Guidelines
|
### Logo Usage Guidelines
|
||||||
|
|
||||||
#### Font used:
|
#### Font used
|
||||||
|
|
||||||
* Lato Black
|
* Lato Black
|
||||||
* Lato Regular
|
* Lato Regular
|
||||||
|
|
||||||
#### Color Palette:
|
#### Color Palette
|
||||||
|
|
||||||
* HEX [#110f0f](https://www.color-hex.com/color/110f0f)
|
* HEX [#110f0f](https://www.color-hex.com/color/110f0f)
|
||||||
* HEX [#ffffff](https://www.color-hex.com/color/ffffff)
|
* HEX [#ffffff](https://www.color-hex.com/color/ffffff)
|
||||||
|
|
||||||
### We kindly ask:
|
### We kindly ask
|
||||||
|
|
||||||
- Please don't use any other font instead of suggested.
|
* Please don't use any other font instead of suggested.
|
||||||
- There should be sufficient clear space around the logo.
|
* There should be sufficient clear space around the logo.
|
||||||
- Do not change spacing, alignment, or relative locations of the design elements.
|
* Do not change spacing, alignment, or relative locations of the design elements.
|
||||||
- Do not change the proportions of any of the design elements or the design itself. You may resize as needed but must retain all proportions.
|
* Do not change the proportions of any of the design elements or the design itself. You may resize as needed but must retain all proportions.
|
||||||
|
Loading…
Reference in New Issue
Block a user