Check out the docs at https://conbench.github.io/conbench.
Conbench allows you to write benchmarks in any language, publish the results as JSON via an API, and persist them for comparison while iterating on performance improvements or to guard against regressions.
Conbench includes a runner which can be used as a stand-alone library for traditional macro benchmark authoring. The runner will time a unit of work (or measure throughput), collect machine information that may be relevant for hardware specific optimizations, and return JSON formatted results.
You can optionally host a Conbench server (API & dashboard) to share benchmark results more widely, explore the changes over time, and compare results across varying benchmark machines, languages, and cases.
There is also a Conbench command line interface, useful for Continuous Benchmarking (CB) orchestration alongside your development pipeline.
The Apache Arrow project is using Conbench for Continuous Benchmarking. They have both native Python Conbench benchmarks, and Conbench benchmarks written in Python that know how to execute their external C++/R/Java/JavaScript benchmarks and record those results too. Those benchmarks can be found in the ursacomputing/benchmarks repository, and the results are hosted on the Arrow Conbench Server.
Most packages in this repo can be installed from PyPI. Each package uses CalVer for versioning. No stability is guaranteed between PyPI versions, so consider pinning packages to a specific version in your code.
pip install benchadapt
pip install benchalerts
pip install benchclients
pip install benchconnect
pip install benchrun
# deprecated; install the webapp or conbenchlegacy from git instead
# pip install conbench
We typically publish to PyPI often, when new features or bugfixes are needed by users,
but not on every merge to main
. To install the latest development version, install
from git like so:
pip install 'benchadapt@git+https://github.com/conbench/conbench.git@main#subdirectory=benchadapt/python'
pip install 'benchalerts@git+https://github.com/conbench/conbench.git@main#subdirectory=benchalerts'
pip install 'benchclients@git+https://github.com/conbench/conbench.git@main#subdirectory=benchclients/python'
pip install 'benchconnect@git+https://github.com/conbench/conbench.git@main#subdirectory=benchconnect'
pip install 'benchrun@git+https://github.com/conbench/conbench.git@main#subdirectory=benchrun/python'
pip install 'conbenchlegacy@git+https://github.com/conbench/conbench.git@main#subdirectory=legacy'
pip install 'conbench@git+https://github.com/conbench/conbench.git@main' # webapp
make
,docker compose
: common developer tasks depend on these tools. They need to be set up on your system.GITHUB_API_TOKEN
environment variable: set up a GitHub API token using GitHub's instructions. It's recommended to only give the token read-only permissions to public repositories (which is the default for fine-grained personal access tokens). Runexport GITHUB_API_TOKEN="{token}"
in your current shell.
The following Makefile targets implement common developer tasks. They assume to be run in the root folder of the repository.
-
make run-app
: This command lets you experiment with Conbench locally. It runs the stack in a containerized fashion. It rebuilds container images from the current checkout, spawns multiple containers (including one for the database), and then exposes Conbench's HTTP server on the host at http://127.0.0.1:5000. The command will stay in the foreground of your terminal, showing log output of all containers. Once you see access log lines likeGET /api/ping/ HTTP/1.1" 200
you can point your browser to http://127.0.0.1:5000. You can useCtrl+C
to terminate the containerized stack (this only stops containers, and the next invocation ofmake run-app
will use previous database state -- invokemake teardown-app
to stop and remove containers). If you wish to clear all database tables during local development you can hit http://127.0.0.1:5000/api/wipe-db with the browser or with e.g. curl. -
make run-app-dev
: Similar tomake run-app
, but also mounts the repository's root directory into the container. Code changes are (should be) detected automatically and result in automatic code reload. -
make tests
: The nobrainer command to run the test suite just like CI does. For more fine-grained control see further below. -
make lint
: Performs invasive code linting in your local checkout. May modify files. Analogue to what CI requires. It requires for some commands to be available in your current shell. Dependencies can be installed withpip install -r requirements-dev.txt
. -
make alembic-new-migration
: Attempts to generate a new migration Python module inmigrations/versions/
. Requires setting the environment variableALEMBIC_MIGRATION_NAME
before invocation. Example:export ALEMBIC_MIGRATION_NAME='repo_url_lenth'
. After the file was created you may want to change its permissions and re-format it withblack
. -
make conbench-on-minikube
: requires minikube. Deploys the Conbench API server to a local minikube-powered Kubernetes cluster. This also deploys a kube-prometheus-based observability stack. Use this target for local development in this area. -
make docs-build
: Builds HTML docs locally so you may check that they render correctly with no linting problems. Dependencies can be installed withpip install -r requirements-dev.txt
. Also, if you're working on the docstrings of any of this repo's python packages, ensure the package is installed locally before using this command.In CI, we use
make build-docs SPHINXOPTS='-W --keep-going'
to fail the build if there are Sphinx warnings. When using this command locally, you can just domake build-docs
, but keep an eye on the warnings.
Point your browser to http://127.0.0.1:5000/api/docs/.
CI and common developer commands use containerized workflows where dependencies are defined and easy to reason about via Dockerfile
s.
Note that the CPython version that Conbench is tested with in CI and that it is recommended to be deployed with is currently the latest 3.11.x release, as also defined in Dockerfile
at the root of this repository.
Some developer tasks may involve running Conbench tooling straight on the host. Here is how to install the Python dependencies for the Conbench web application:
pip install -r requirements-webapp.txt
Dependencies for running code analysis and tests straight on the host can be installed with
pip install -r requirements-dev.txt
If make test
is too coarse-grained, then this is how to take control of the containerized pytest
test runner:
docker compose down && docker compose build app && \
docker compose run app \
pytest -vv conbench/tests
This command attempts to stop and remove previously spawned test runner containers, and it rebuilds the app
container image prior to running tests to pick up code changes in the local checkout.
Useful command line arguments for local development (can be combined as desired):
... pytest -k test_login
: run only string-matching tests... pytest -x
: exit upon first error... pytest -s
: do not swallow log output during run... run -e CONBENCH_LOG_LEVEL_STDERR=DEBUG app ...
The following commands are not guaranteed to work as documented, but provide valuable inspiration:
(conbench) $ brew services start postgres
(conbench) $ dropdb conbench_prod
(conbench) $ createdb conbench_prod
(conbench) $ git checkout main && git pull
(conbench) $ alembic upgrade head
(conbench) $ git checkout your-branch
(conbench) $ alembic revision --autogenerate -m "new"
-
Start conbench app in Terminal window 1:
(conbench) $ dropdb conbench_prod && createdb conbench_prod && alembic upgrade head && flask run
-
Run
conbench.tests.populate_local_conbench
in Terminal window 2 while conbench app is running:(conbench) $ python -m conbench.tests.populate_local_conbench
Kick off a new run of the "Build and upload a package to PyPI" workflow on the Actions page.
To add a new page to our GitHub Pages-hosted documentation:
- Add a Markdown file to
docs/pages/
. - In the toctree in the
docs/index.rst
file, addpages/your_new_page
, whereyour_new_page
is your new filename without the.md
file suffix.
To test that your new pages pass our documentation linter, run the make docs-build
command, as described above.
The conbench web application can be configured with various environment variables as defined in config.py. Instructions are in that file.
By default, conbench has open read access, so a user account is not required to view results or read from the API. An account is required only if the conbench instance is private or to write data to conbench.
If you do need an account, follow the login screen's "Sign Up" link, and use the registration key specified in the server configuration above. If you are a user of conbench, you may need to talk to your user administrator to get the registration key. SSO can be configured to avoid requiring the registration key.
If you have an account and need to create an additional account (say for a machine user of the API) either repeat the process if you have the registration key, or if you don't have the registration key (say if your account uses SSO), when logged in, go to the gear menu / Users and use the "Add User" button to create a new account without the registration key.