This repository is the UI component of the test framework which includes 100% of code used to run https://db-benchmarks.com/ . You can easily setup your own version of the site for your local benchmarks.
Read about the project in general in its main repo - https://github.com/db-benchmarks/db-benchmarks
Please find instructions here on populating your local database with test results.
Clone the repository and update the submodules:
git clone [email protected]:db-benchmarks/ui.git db-benchmarks-site
cd db-benchmarks-site
cp .env_example .env
git submodule update --init site/themes/LoveIt
git submodule update --init --remote site/db-benchmarks
docker-compose up
# wait until it fully starts, then in another terminal tab:
./site/db-benchmarks/test --save=./site/db-benchmarks/results --host=db.localhost --port=80 --username=bench --password=bench
# stop the docker-compose and start it with -d, so it runs in background
docker-compose up -d
This should run a full copy of https://db-benchmarks.com on http://localhost (with the db running at http://bench:[email protected] , you need to add it to your hosts file).
To modify the hostname, db username/password update .env
and:
docker-compose down
docker-compose up -d
By default it listens on port 80, but you can easily install Let's Encrypt certificates. Just run:
docker-compose exec nginx certbot --nginx
and answer certbot's questions (your email etc). After that run:
docker-compose exec nginx sed -i "s/listen 443 ssl;/listen 443 ssl http2;/" /etc/nginx/conf.d/site.conf
docker-compose restart nginx
to enable http/2 for the site.
It will put the certificates to ./nginx/ssl/
and will update your Nginx configs in ./nginx/conf/
. After that to prevent the configs from further overriding from the templates in ./nginx/templates/
you need to update your .env
file like this:
- NGINX_TEMPLATES_DIR=/etc/nginx/templates
+ NGINX_TEMPLATES_DIR=/tmp/
To renew your certificates in few months just run:
docker-compose exec nginx certbot renew
docker-compose exec nginx sed -i "s/listen 443 ssl;/listen 443 ssl http2;/" /etc/nginx/conf.d/site.conf
docker-compose restart nginx
- The original test results layout was heavily inspired by Clickhouse Benchmarks - https://clickhouse.com/benchmark/dbms/ . Thank you, Alexey Milovidov and Clickhouse team!
- To enable Google analytics add
VUE_APP_GA
to.env
andparams.analytics.google.id
to site'sconfig.toml