This Cargo project implements various benchmarks for SQLx using Criterion.
- Group
pg_pool
: benchmarkssqlx::Pool
against a PostgreSQL server.DATABASE_URL
must be set (or in.env
) pointing to a PostgreSQL server. It should preferably be running on the same machine as the benchmarks to reduce latency.- The
postgres
feature must be enabled for this benchmark to run. - Benchmarks:
bench_pgpool_acquire
: benchmarksPool::acquire()
when many concurrent tasks are also using the pool, with or without the pool being fair. Concurrently to the benchmark iteration function calling and blocking onPool::acquire()
, a varying number of background tasks are also callingacquire()
and holding the acquired connection for 500µs each before releasing it back to the pool. The pool is created with.min_size(50).max_size(50)
so we shouldn't be measuring anything but the actual overhead ofPool
's bookeeping.
You must choose a runtime to execute the benchmarks on; the feature flags are the same as the sqlx
crate:
cargo bench --features runtime-tokio
cargo bench --features runtime-async-std
When complete, the benchmark results will be in target/criterion/
.
Open target/criterion/report/index.html
or pick one of the benchmark subfolders and open
report/index.html
there to view the results.
If you want to share the results here, please follow the format below.