Can we introduce a new managed connection pool implementation that reduces thread contention under load?
johara Jun 5, 2014 2:40 AMWe have been profiling a number of JEE benchmarks that we run on WF (IJ 1.1) and EAP (IJ 1.0), and in a couple of cases we see the most contended object within the JVM is a java.util.ArrayList object (cls). High thread contention on any object causes us scaling issues as we increase throughput, more threads on the critical path are blocked waiting to synchronize on the intrinsic lock and this creates a performance bottleneck preventing us from scaling higher.
The method calls where most contention occurs are;
- org.jboss.jca.core.connectionmanager.pool.mcp.SemaphoreArrayListManagedConnectionPool.isSize(int)
- org.jboss.jca.core.connectionmanager.pool.mcp.SemaphoreArrayListManagedConnectionPool.getConnection(Subject, ConnectionRequestInfo)
IsSize is called a lot within SemaphoreArrayListManagedConnectionPool.returnConnection(ConnectionListener, boolean, boolean), so we are seeing most contention when returning a connection back to the connection pool.
We have been looking at a potential alternative implementation to SemaphoreArrayListManagedConnectionPool that does not require extensive intrinsic locking on key data structures within the connection pool to eliminate the thread contention we see withing the SemaphoreArrayListManagedConnectionPool. The alternative implementation could be selected via the -Dironjacamar.mcp system property, leaving SemaphoreArrayListManagedConnectionPool as the default implementation.
The alternative implementation that we have been working on (NonBlockingManagedConnectionPool) can be found here;
https://github.com/johnaoahra80/ironjacamar/commits/1.2_nonBlockingMcp
We have been testing this NonBlockingManagedConnectionPool implementation with our benchmarks and can see that the thread contention has been eliminated. The implementation is passing all the junit tests within the testsuite (changes are required to the byteman tests from SemaphoreArrayListManagedConnectionPool to NonBlockingManagedConnectionPool in order for the byteman scripts to be injected into the correct class).
Running the performance testsuite, it shows higher throughput mainly in circumstances where the connection pool is highly contended.
NarayanaFilePerfTestCase | NarayanaMemPerfTestCase | NoopTSPerfTestCase | |||||||||||
Default | Non Blocking | % difference | Default | Non Blocking | % difference | Default | Non Blocking | % difference | |||||
Time elapsed: | 7.547 sec | 4.94 sec | 7.468 sec | 4.893 sec | 6.443 sec | 3.536 sec | |||||||
PERF-DATA: | LocalTransaction | 1 | 8599 | 8,413 | -2.2% | 8,579 | 8,632 | 0.6% | 19,593 | 19,513 | -0.4% | ||
PERF-DATA: | LocalTransaction | 10 | 61481 | 69,314 | 12.7% | 68,519 | 56,991 | -16.8% | 119,156 | 140,113 | 17.6% | ||
PERF-DATA: | LocalTransaction | 25 | 127345 | 129,850 | 2.0% | 137,307 | 138,239 | 0.7% | 129,795 | 196,722 | 51.6% | ||
PERF-DATA: | LocalTransaction | 50 | 156398 | 158,878 | 1.6% | 166,465 | 204,386 | 22.8% | 201,999 | 419,632 | 107.7% | ||
PERF-DATA: | LocalTransaction | 100 | 178719 | 347,799 | 94.6% | 208,539 | 323,922 | 55.3% | 332,415 | 501,224 | 50.8% | ||
PERF-DATA: | LocalTransaction | 150 | 264262 | 524,750 | 98.6% | 272,095 | 584,342 | 114.8% | 289,253 | 1,023,686 | 253.9% | ||
PERF-DATA: | LocalTransaction | 200 | 267673 | 568,580 | 112.4% | 262,701 | 562,689 | 114.2% | 286,730 | 1,064,672 | 271.3% | ||
PERF-DATA: | LocalTransaction | 250 | 252210 | 544,979 | 116.1% | 258,285 | 574,405 | 122.4% | 264,239 | 947,305 | 258.5% | ||
PERF-DATA: | LocalTransaction | 300 | 243594 | 642,158 | 163.6% | 256,127 | 635,422 | 148.1% | 245,277 | 919,591 | 274.9% | ||
PERF-DATA: | NoTransaction | 1 | 7344 | 7,344 | 0.0% | 7301 | 7,302 | 0.0% | 18229 | 18,855 | 3.4% | ||
PERF-DATA: | NoTransaction | 10 | 74046 | 73,724 | -0.4% | 75,895 | 72,543 | -4.4% | 59,277 | 138,621 | 133.9% | ||
PERF-DATA: | NoTransaction | 25 | 83172 | 194,889 | 134.3% | 90,805 | 164,350 | 81.0% | 116,145 | 279,093 | 140.3% | ||
PERF-DATA: | NoTransaction | 50 | 140919 | 174,073 | 23.5% | 132,684 | 220,180 | 65.9% | 443,173 | 747,565 | 68.7% | ||
PERF-DATA: | NoTransaction | 100 | 164386 | 127,074 | -22.7% | 157,417 | 121,349 | -22.9% | 508,124 | 765,736 | 50.7% | ||
PERF-DATA: | NoTransaction | 150 | 318823 | 1,251,051 | 292.4% | 298,013 | 1,280,842 | 329.8% | 466,142 | 1,302,376 | 179.4% | ||
PERF-DATA: | NoTransaction | 200 | 336479 | 1,127,861 | 235.2% | 352,969 | 1,104,635 | 213.0% | 495,538 | 1,063,839 | 114.7% | ||
PERF-DATA: | NoTransaction | 250 | 355403 | 1,410,671 | 296.9% | 360,449 | 1,359,957 | 277.3% | 498,298 | 1,237,114 | 148.3% | ||
PERF-DATA: | NoTransaction | 300 | 340000 | 1,310,081 | 285.3% | 338,720 | 1,302,579 | 284.6% | 470,399 | 1,140,757 | 142.5% | ||
PERF-DATA: | XATransaction | 1 | 38094 | 35,099 | -7.9% | 37,798 | 39,333 | 4.1% | 175,625 | 279,412 | 59.1% | ||
PERF-DATA: | XATransaction | 10 | 232277 | 216,117 | -7.0% | 235515 | 259,333 | 10.1% | 321395 | 880,533 | 174.0% | ||
PERF-DATA: | XATransaction | 25 | 270222 | 647,514 | 139.6% | 232,424 | 609,369 | 162.2% | 392,324 | 947,380 | 141.5% | ||
PERF-DATA: | XATransaction | 50 | 288038 | 658,361 | 128.6% | 279,379 | 651,952 | 133.4% | 346,978 | 909,624 | 162.2% | ||
PERF-DATA: | XATransaction | 100 | 273321 | 605,051 | 121.4% | 271,742 | 609,769 | 124.4% | 275,187 | 856,115 | 211.1% | ||
PERF-DATA: | XATransaction | 150 | 262343 | 655,093 | 149.7% | 274,100 | 653,479 | 138.4% | 299,671 | 950,689 | 217.2% | ||
PERF-DATA: | XATransaction | 200 | 248658 | 649,045 | 161.0% | 272,798 | 624,137 | 128.8% | 292,491 | 983,790 | 236.3% | ||
PERF-DATA: | XATransaction | 250 | 256476 | 652,559 | 154.4% | 263,626 | 637,521 | 141.8% | 264,884 | 1,036,293 | 291.2% | ||
PERF-DATA: | XATransaction | 300 | 239161 | 626,282 | 161.9% | 259,713 | 601,973 | 131.8% | 243,082 | 1,028,967 | 323.3% | ||
Testcase: | testNo | took | 2.49 | 1.8 | 27.7% | 2.544 | 1.769 | 30.5% | 1.878 | 1.199 | 36.2% | ||
Testcase: | testLocal | took | 2.392 | 1.48 | 38.1% | 2.334 | 1.47 | 37.0% | 2.123 | 1.014 | 52.2% | ||
Testcase: | testXA | took | 2.097 | 1.085 | 48.3% | 2.027 | 1.102 | 45.6% | 1.958 | 0.832 | 57.5% |