HammerDB is a great tool for running Database benchmarks. However it is very easy to create an artificial bottleneck which will give a very poor benchmark result.
When setting up HammerDB to run against even a moderate modern server, it is important to avoid displaying the client transaction outputs in the HammerDB UI.
In my case just making this simple changed increased my HammerDB results by over 6X. The reason is that HammerDB spends more time updating its own UI, than it does sending transactions to the DB. When I run HammerDB, I select “Log Output to Temp” and “Use Unique Log Name”.
- Un-check the “Show results” mark.
- Or Ensure that the results are logged to file, not displayed on screen
- Otherwise the workload generator will become the bottleneck.
Checked -> 124,000 tpm Un-Checked -> 800,000 tpm< /pre>