Skip to content

Benchmarking Scalability of Distributed Stream Processing Engines

License

Notifications You must be signed in to change notification settings

lorenzboguhn/theodolite

 
 

Repository files navigation

Theodolite

A theodolite is a precision optical instrument for measuring angles between designated visible points in the horizontal and vertical planes. -- Wikipedia

Theodolite is a framework for benchmarking the horizontal and vertical scalability of stream processing engines. It consists of three modules:

Theodolite Benchmarks

Theodolite contains 4 application benchmarks, which are based on typical use cases for stream processing within microservices. For each benchmark, a corresponding workload generator is provided. Currently, this repository provides benchmark implementations for Apache Kafka Streams and Apache Flink. The benchmark sources can be found in Thedolite benchmarks.

Theodolite Execution Framework

Theodolite aims to benchmark scalability of stream processing engines for real use cases. Microservices that apply stream processing techniques are usually deployed in elastic cloud environments. Hence, Theodolite's cloud-native benchmarking framework deploys its components in a cloud environment, orchestrated by Kubernetes. More information on how to execute scalability benchmarks can be found in Thedolite execution framework.

Theodolite Analysis Tools

Theodolite's benchmarking method creates a scalability graph allowing to draw conclusions about the scalability of a stream processing engine or its deployment. A scalability graph shows how resource demand evolves with an increasing workload. Theodolite provides Jupyter notebooks for creating such scalability graphs based on benchmarking results from the execution framework. More information can be found in Theodolite analysis tool.

How to Cite

If you use Theodolite, please cite

Sören Henning and Wilhelm Hasselbring. (2021). Theodolite: Scalability Benchmarking of Distributed Stream Processing Engines in Microservice Architectures. Big Data Research, Volume 25. DOI: 10.1016/j.bdr.2021.100209. arXiv:2009.00304.

About

Benchmarking Scalability of Distributed Stream Processing Engines

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Java 47.1%
  • Kotlin 43.8%
  • Jupyter Notebook 5.9%
  • Python 1.5%
  • Dockerfile 0.7%
  • Shell 0.6%
  • Smarty 0.4%