This commit is contained in:
Aliaksandr Valialkin 2024-05-09 17:19:03 +02:00
parent 15587dc63e
commit dcda92dd89
No known key found for this signature in database
GPG key ID: 52C003EE2BCDB9EB

View file

@ -6,7 +6,7 @@ Logs generator for [VictoriaLogs](https://docs.victoriametrics.com/victorialogs/
Run `make vlogsgenerator` from the repository root. This builds `bin/vlogsgenerator` binary. Run `make vlogsgenerator` from the repository root. This builds `bin/vlogsgenerator` binary.
## How to generate logs? ## How run vlogsgenerator?
`vlogsgenerator` generates logs in [JSON line format](https://jsonlines.org/) suitable for the ingestion `vlogsgenerator` generates logs in [JSON line format](https://jsonlines.org/) suitable for the ingestion
via [`/insert/jsonline` endpoint at VictoriaLogs](https://docs.victoriametrics.com/victorialogs/data-ingestion/#json-stream-api). via [`/insert/jsonline` endpoint at VictoriaLogs](https://docs.victoriametrics.com/victorialogs/data-ingestion/#json-stream-api).
@ -72,6 +72,8 @@ Below is an example output:
} }
``` ```
### How to write logs to VictoriaLogs?
The generated logs can be written directly to VictoriaLogs by passing the address of [`/insert/jsonline` endpoint](https://docs.victoriametrics.com/victorialogs/data-ingestion/#json-stream-api) The generated logs can be written directly to VictoriaLogs by passing the address of [`/insert/jsonline` endpoint](https://docs.victoriametrics.com/victorialogs/data-ingestion/#json-stream-api)
to `-addr` command-line flag. For example, the following command writes the generated logs to VictoriaLogs running at `localhost`: to `-addr` command-line flag. For example, the following command writes the generated logs to VictoriaLogs running at `localhost`:
@ -79,6 +81,8 @@ to `-addr` command-line flag. For example, the following command writes the gene
bin/vlogsgenerator -addr=http://localhost:9428/insert/jsonline bin/vlogsgenerator -addr=http://localhost:9428/insert/jsonline
``` ```
### Configuration
`vlogsgenerator` accepts various command-line flags, which can be used for configuring the number and the shape of the generated logs. `vlogsgenerator` accepts various command-line flags, which can be used for configuring the number and the shape of the generated logs.
These flags can be inspected by running `vlogsgenerator -help`. Below are the most interesting flags: These flags can be inspected by running `vlogsgenerator -help`. Below are the most interesting flags:
@ -101,6 +105,26 @@ bin/vlogsgenerator \
-addr=http://localhost:9428/insert/jsonline -addr=http://localhost:9428/insert/jsonline
``` ```
### Churn rate
It is possible to generate churn rate for active [log streams](https://docs.victoriametrics.com/VictoriaLogs/keyConcepts.html#stream-fields)
by specifying `-totalStreams` command-line flag bigger than `-activeStreams`. For example, the following command generates
logs for `1000` total streams, while the number of active streams equals to `100`. This means that at every time there are logs for `100` streams,
but these streams change over the given [`-start` ... `-end`] time range, so the total number of streams on the given time range becomes `1000`:
```
bin/vlogsgenerator \
-start=2024-01-01 -end=2024-02-01 \
-activeStreams=100 \
-totalStreams=1_000 \
-logsPerStream=10_000 \
-addr=http://localhost:9428/insert/jsonline
```
In this case the total number of generated logs equals to `-totalStreams` * `-logsPerStream` = `10_000_000`.
### Benchmark tuning
By default `vlogsgenerator` generates and writes logs by a single worker. This may limit the maximum data ingestion rate during benchmarks. By default `vlogsgenerator` generates and writes logs by a single worker. This may limit the maximum data ingestion rate during benchmarks.
The number of workers can be changed via `-workers` command-line flag. For example, the following command generates and writes logs with `16` workers: The number of workers can be changed via `-workers` command-line flag. For example, the following command generates and writes logs with `16` workers:
@ -113,6 +137,8 @@ bin/vlogsgenerator \
-workers=16 -workers=16
``` ```
### Output statistics
Every 10 seconds `vlogsgenerator` writes statistics about the generated logs into `stderr`. The frequency of the generated statistics can be adjusted via `-statInterval` command-line flag. Every 10 seconds `vlogsgenerator` writes statistics about the generated logs into `stderr`. The frequency of the generated statistics can be adjusted via `-statInterval` command-line flag.
For example, the following command writes statistics every 2 seconds: For example, the following command writes statistics every 2 seconds: