2023-07-14 20:06:27 +00:00
---
2023-10-14 11:45:57 +00:00
weight: 5
2023-07-14 20:06:27 +00:00
title: Vector setup
2023-07-14 20:56:38 +00:00
disableToc: true
2023-07-14 20:06:27 +00:00
menu:
docs:
parent: "victorialogs-data-ingestion"
2023-10-14 11:45:57 +00:00
weight: 5
2023-07-14 20:56:38 +00:00
aliases:
- /VictoriaLogs/data-ingestion/Vector.html
2023-07-14 20:06:27 +00:00
---
2023-06-21 14:58:43 +00:00
# Vector setup
2023-06-22 01:31:50 +00:00
Specify [Elasticsearch sink type ](https://vector.dev/docs/reference/configuration/sinks/elasticsearch/ ) in the `vector.toml`
2023-10-14 12:41:04 +00:00
for sending the collected logs to [VictoriaLogs ](/VictoriaLogs/ ):
2023-06-21 14:58:43 +00:00
```toml
[sinks.vlogs]
inputs = [ "your_input" ]
type = "elasticsearch"
endpoints = [ "http://localhost:9428/insert/elasticsearch/" ]
mode = "bulk"
api_version = "v8"
healthcheck.enabled = false
[sinks.vlogs.query]
_msg_field = "message"
_time_field = "timestamp"
_stream_fields = "host,container_name"
```
Substitute the `localhost:9428` address inside `endpoints` section with the real TCP address of VictoriaLogs.
Replace `your_input` with the name of the `inputs` section, which collects logs. See [these docs ](https://vector.dev/docs/reference/configuration/sources/ ) for details.
2023-10-14 12:41:04 +00:00
See [these docs ](/VictoriaLogs/data-ingestion/#http-parameters ) for details on parameters specified
2023-06-22 01:31:50 +00:00
in the `[sinks.vlogs.query]` section.
2023-10-14 12:41:04 +00:00
It is recommended verifying whether the initial setup generates the needed [log fields ](/VictoriaLogs/keyConcepts.html#data-model )
and uses the correct [stream fields ](/VictoriaLogs/keyConcepts.html#stream-fields ).
This can be done by specifying `debug` [parameter ](/VictoriaLogs/data-ingestion/#http-parameters )
2023-06-22 01:31:50 +00:00
in the `[sinks.vlogs.query]` section and inspecting VictoriaLogs logs then:
2023-06-21 14:58:43 +00:00
2023-06-22 01:31:50 +00:00
```toml
[sinks.vlogs]
inputs = [ "your_input" ]
type = "elasticsearch"
endpoints = [ "http://localhost:9428/insert/elasticsearch/" ]
mode = "bulk"
api_version = "v8"
healthcheck.enabled = false
2023-06-21 14:58:43 +00:00
2023-06-22 01:31:50 +00:00
[sinks.vlogs.query]
_msg_field = "message"
_time_field = "timestamp"
_stream_fields = "host,container_name"
debug = "1"
```
2023-06-21 14:58:43 +00:00
2023-10-14 12:41:04 +00:00
If some [log fields ](/VictoriaLogs/keyConcepts.html#data-model ) must be skipped
during data ingestion, then they can be put into `ignore_fields` [parameter ](/VictoriaLogs/data-ingestion/#http-parameters ).
2023-06-21 14:58:43 +00:00
For example, the following config instructs VictoriaLogs to ignore `log.offset` and `event.original` fields in the ingested logs:
```toml
[sinks.vlogs]
inputs = [ "your_input" ]
type = "elasticsearch"
endpoints = [ "http://localhost:9428/insert/elasticsearch/" ]
mode = "bulk"
api_version = "v8"
healthcheck.enabled = false
[sinks.vlogs.query]
_msg_field = "message"
_time_field = "timestamp"
_stream_fields = "host,container_name"
ignore_fields = "log.offset,event.original"
```
When Vector ingests logs into VictoriaLogs at a high rate, then it may be needed to tune `batch.max_events` option.
For example, the following config is optimized for higher than usual ingestion rate:
```toml
[sinks.vlogs]
inputs = [ "your_input" ]
type = "elasticsearch"
endpoints = [ "http://localhost:9428/insert/elasticsearch/" ]
mode = "bulk"
api_version = "v8"
healthcheck.enabled = false
[sinks.vlogs.query]
_msg_field = "message"
_time_field = "timestamp"
_stream_fields = "host,container_name"
[sinks.vlogs.batch]
max_events = 1000
```
2023-06-22 01:31:50 +00:00
If the Vector sends logs to VictoriaLogs in another datacenter, then it may be useful enabling data compression via `compression = "gzip"` option.
2023-06-21 14:58:43 +00:00
This usually allows saving network bandwidth and costs by up to 5 times:
```toml
[sinks.vlogs]
inputs = [ "your_input" ]
type = "elasticsearch"
endpoints = [ "http://localhost:9428/insert/elasticsearch/" ]
mode = "bulk"
api_version = "v8"
healthcheck.enabled = false
compression = "gzip"
[sinks.vlogs.query]
_msg_field = "message"
_time_field = "timestamp"
_stream_fields = "host,container_name"
```
2023-10-14 12:41:04 +00:00
By default, the ingested logs are stored in the `(AccountID=0, ProjectID=0)` [tenant ](/VictoriaLogs/keyConcepts.html#multitenancy ).
2023-06-22 01:31:50 +00:00
If you need storing logs in other tenant, then specify the needed tenant via `[sinks.vlogq.request.headers]` section.
For example, the following `vector.toml` config instructs Vector to store the data to `(AccountID=12, ProjectID=34)` tenant:
2023-06-21 14:58:43 +00:00
```toml
[sinks.vlogs]
inputs = [ "your_input" ]
type = "elasticsearch"
endpoints = [ "http://localhost:9428/insert/elasticsearch/" ]
mode = "bulk"
api_version = "v8"
healthcheck.enabled = false
[sinks.vlogs.query]
_msg_field = "message"
_time_field = "timestamp"
_stream_fields = "host,container_name"
[sinks.vlogs.request.headers]
AccountID = "12"
ProjectID = "34"
```
2023-06-22 01:31:50 +00:00
See also:
2023-06-21 14:58:43 +00:00
2023-10-14 12:41:04 +00:00
- [Data ingestion troubleshooting ](/VictoriaLogs/data-ingestion/#troubleshooting ).
- [How to query VictoriaLogs ](/VictoriaLogs/querying/ ).
2023-06-22 02:39:22 +00:00
- [Elasticsearch output docs for Vector ](https://vector.dev/docs/reference/configuration/sinks/elasticsearch/ ).
2023-06-22 01:31:50 +00:00
- [Docker-compose demo for Filebeat integration with VictoriaLogs ](https://github.com/VictoriaMetrics/VictoriaMetrics/tree/master/deployment/docker/victorialogs/vector-docker ).