Skip to main content

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

CI Coverage Status License Downloads per month

Supported Python versions Status Package version

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.

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tsperf-1.2.1.tar.gz (60.4 kB view details)

Uploaded Source

Built Distribution

tsperf-1.2.1-py3-none-any.whl (93.0 kB view details)

Uploaded Python 3

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

Hashes for tsperf-1.2.1.tar.gz
Algorithm Hash digest
SHA256 51ec301efee6a5b28b8267647fda24552b76fc59b86f34ec545ff908a21d35f9
MD5 dc482997b22e3b43b11b5b032c2d124e
BLAKE2b-256 625120d11407825d4e385d724496df8c5091c63a03ef1cc981085188a0c28068

See more details on using hashes here.

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

Hashes for tsperf-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5127f487eba219cf4f8782dc3977752aaa36c60b8e5810baa48412f2355a3dc0
MD5 f4e7c488fc21c9b5c518c77ae2683b57
BLAKE2b-256 43d1f5cd361705208266ea6b8b109c3191bd430da91e8a62586e5862ec23a00d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page