Biased locking Obsoletion

Andrew Dinn adinn at redhat.com
Mon Nov 9 12:11:22 UTC 2020


On 06/11/2020 18:36, Andrew Haley wrote:
> On 11/6/20 5:29 PM, Doerr, Martin wrote:
>> My impression is that modern workloads are fine without BL, so typical JDK15 users will probably not notice it was switched off.
> 
> I don't believe they are, because there are several (many?) places in
> the Java library that perform badly. In particular, see JDK-8254078,
> DataOutputStream is very slow post-disabling of Biased Locking.
> 
> This is not a solved problem, and I don't know what a "typical"
> user is, but some users may experience significant performance
> degradation. This is not a solved problem.
Red Hat has been conducting an internal review of our middleware 
products to assess the impact of biased lock removal. For the cases we 
have been able to test (which we acknowledge are /far/ from 
comprehensive) we have not found any clear picture of outright gain or 
loss in performance in the middleware code per se. We have almost always 
seen small improvements or degradations in performance (sometimes in the 
same product with different workloads).

The only case where we have seen a significant loss of performance with 
biased locking disabled was for our Transactions product when running in 
a /non-production/ operational mode. That specific degradation was not 
directly caused by our middleware implementation. It resulted from 
unnecessary and unavoidable synchronization overheads in /standard/ JDK 
library code that the middleware relied on (specifically, the 
DataOutputStream issue that Andrew Haley addressed in JDK-8254078).

Note that this issue did not affect /production/ operational modes 
because in those modes the extra synch costs were amortized across 
storage access costs. We think the same story most likely explains the 
lack of significant degradation for our other middleware products. 
However, that does not mean the JDK gets the all clear. Indeed, it may 
not even leave our middleware in the clear. With only limited testing we 
cannot be sure storage costs will mask synchronizations costs in all 
production use cases.

More generally, it is quite probable that there are applications built 
over DataOutputStream or other JDK XXXOutputStream APIs (perhaps also 
other class hierarchies) which don't suffer from synchronization costs 
at present but are going to hit problems when biased locking is removed. 
The argument from David Holmes that:

   Real "old" code would have been updated years ago to move away from 
the synchronized library classes

misses the obvious point that "real, old code" and, quite possibly, some 
"real, relatively new code" will not have manifested performance issues 
when using these old skool JDK classes with biased locking enabled. 
Relying on users to have already fixed problems when they are not 
visible prior to the deprecation change seems to me, at best, unrealistic.

I also feel that relying on users to come up their own alternatives to 
work around the limitations of these /standard/ classes -- if and when 
problems do turn up -- would be an inadequate response. If a need 
emerges for unsynchronized, non-thread safe alternatives to JDK library 
classes because of this JVM change then I think it would be appropriate 
for that need to be met by upgrading the JDK itself to provide either an 
alternative class or alternative mode of operation for the existing 
class. A common, well built, integrated solution would be preferable to 
many ad hoc alternatives.


Andrew Dinn
-----------
Red Hat Distinguished Engineer
Red Hat UK Ltd
Registered in England and Wales under Company Registration No. 03798903
Directors: Michael Cunningham, Michael ("Mike") O'Neill



More information about the hotspot-dev mailing list