Skip to content

Benchmarks for various object pools that run on the JVM. Built with JMH.

License

Notifications You must be signed in to change notification settings

dimzon/object-pool-benchmarks

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Build the benchmarks like this:

mvn clean package

Run the full benchmark suite (note that this will take a while) like this:

./fullsuite.sh

The results of the fullsuite benchmark will be put in a new subdirectory of results.

Run individual benchmarks like this:

java -jar target/object-pool-benchmarks.jar ".*ClaimRelease.*"

For instance, running a single-threaded claim-release throughput benchmark could look like this:

java -jar target/object-pool-benchmarks.jar ".*ClaimRelease.*" -t 1 -i 6 -wi 6 -f 1 -tu ms -bm thrpt

Set pool-size by specifying -jvmArgs -Dpool.size=10.

Likewise set the cost.of.allocation, cost.of.deallocation and cost.of.validation objects.

The cost is expressed in units of 'cpu' (arbitary but stable units of CPU busy-work) or 'ms' (milliseconds of sleep) like so: -jvmArgs -Dcost.of.allocation=100cpu. By default there is no cost.

Specially configured executions do not automatically save their results in the results directory. Only the fullsuite execution does that.

Ask JMH for further possible CLI configurations like this:

java -jar target/object-pool-benchmarks.jar -h

About

Benchmarks for various object pools that run on the JVM. Built with JMH.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 91.5%
  • Shell 4.3%
  • Python 4.2%