A tool to test performance of time-series databases
Project description
TSPERF Time Series Database Benchmark Suite
TSPERF is a tool for evaluating and comparing the performance of time series databases, in the spirit of TimescaleDB's Time Series Benchmark Suite (TSBS).
» Documentation | Changelog | PyPI | Issues | Source code | License
About
The tsperf
program includes both a database workload generator, and a query
timer. That effectively spans two domains, one for writing data, and another
one for reading.
- Data Generator: Generate time series data and feed it into database.
Use
tsperf write --help
to explore its options. - Query Timer: Probe responsiveness of database on the read path.
Use
tsperf read --help
to explore its options.
For the purpose of capacity testing, both domains try to simulate the generation and querying of time-series data. As the program is easy to use, it provides instant reward without the need to set up a whole data ingestion chain.
Features
General
- Generate random data which follows a statistical model to better reflect real world scenarios, real world data is almost never truly random.
- The "steady load"-mode can simulate a constant load of a defined number of messages per second.
- Ready-made to deploy and scale data generators with Docker containers. In order to maximize performance, multiple instances of the data generator can be run in parallel. This can be achieved by parallelizing using Kubernetes.
- Metrics are exposed for consumption by Prometheus.
Data Generator
- Capability to define your own schema.
- Full control on how many values will be inserted.
- Scale out to multiple clients is a core concept.
- Huge sets of data can be inserted without creating files as intermediate storage.
Database Coverage
- CrateDB
- InfluxDB
- Microsoft SQL Server
- MongoDB
- PostgreSQL
- TimescaleDB
- Timestream
Install
Python package
pip install --user tsperf
Docker image
alias tsperf="docker run -it --rm --network=host ghcr.io/crate/tsperf:latest tsperf"
tsperf --help
Usage
Please refer to the usage documentation.
Prior Art
cr8 + mkjson
mkjson
combined with cr8 insert-json
makes it easy to generate random entries into a table.
See generate data sets using mkjson for an example how to use cr8
together with mkjson
.
TSBS
The Time Series Benchmark Suite (TSBS) is a collection of Go programs that are used to generate datasets and then benchmark read and write performance of various databases.
Project Information
Contributing
We are always happy to receive code contributions, ideas, suggestions and problem reports from the community.
So, if you’d like to contribute you’re most welcome. Spend some time taking a look around, locate a bug, design issue or spelling mistake and then send us a pull request or open an issue on GitHub.
Thanks in advance for your efforts, we really appreciate any help or feedback.
Acknowledgements
Thanks to all the contributors who helped to co-create and conceive tsperf
in one way or another and kudos to all authors of the foundational libraries.
License
This project is licensed under the terms of the Apache 2.0 license.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file tsperf-1.2.1.tar.gz
.
File metadata
- Download URL: tsperf-1.2.1.tar.gz
- Upload date:
- Size: 60.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 51ec301efee6a5b28b8267647fda24552b76fc59b86f34ec545ff908a21d35f9 |
|
MD5 | dc482997b22e3b43b11b5b032c2d124e |
|
BLAKE2b-256 | 625120d11407825d4e385d724496df8c5091c63a03ef1cc981085188a0c28068 |
File details
Details for the file tsperf-1.2.1-py3-none-any.whl
.
File metadata
- Download URL: tsperf-1.2.1-py3-none-any.whl
- Upload date:
- Size: 93.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.12.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5127f487eba219cf4f8782dc3977752aaa36c60b8e5810baa48412f2355a3dc0 |
|
MD5 | f4e7c488fc21c9b5c518c77ae2683b57 |
|
BLAKE2b-256 | 43d1f5cd361705208266ea6b8b109c3191bd430da91e8a62586e5862ec23a00d |