Contents
Benchmarks
Summary
On average, pg_uuidv7
is nearly as fast as the native gen_random_uuid()
function in Postgres. It is perhaps 2% slower in a worst case scenario, however
run-to-run variations of pgbench
were >2%, which likely means that in a real
system the performance impact of pg_uuidv7
is negligible.
Methods
Performance benchmarks were evaluated using pgbench
. The following functions
were benchmarked:
- the native
gen_random_uuid()
function which is built in since Postgres 13 - the
uuid_generate_v7()
function from this extension (pg_uuidv7
) - a pure sql version of
uuid_generate_v7()
from kjmph
Results
``` pgbench --client=8 --jobs=8 --transactions=200000 --file=${TEST}.sql
-- SELECT gen_random_uuid(); scaling factor: 1 query mode: simple number of clients: 8 number of threads: 8 maximum number of tries: 1 number of transactions per client: 200000 number of transactions actually processed: 1600000/1600000 number of failed transactions: 0 (0.000%) latency average = 0.096 ms initial connection time = 6.653 ms tps = 83478.089558 (without initial connection time)
-- pg_uuidv7 C extension scaling factor: 1 query mode: simple number of clients: 8 number of threads: 8 maximum number of tries: 1 number of transactions per client: 200000 number of transactions actually processed: 1600000/1600000 number of failed transactions: 0 (0.000%) latency average = 0.098 ms initial connection time = 6.908 ms tps = 81562.002058 (without initial connection time)
-- sql function r18 scaling factor: 1 query mode: simple number of clients: 8 number of threads: 8 maximum number of tries: 1 number of transactions per client: 200000 number of transactions actually processed: 1600000/1600000 number of failed transactions: 0 (0.000%) latency average = 0.123 ms initial connection time = 7.602 ms tps = 65269.760532 (without initial connection time) ```