<div dir="ltr">I see, make sense, thanks for the clarification.</div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Feb 21, 2024 at 11:49 AM masoud parvari <<a href="mailto:masoud.parvari@gmail.com">masoud.parvari@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr">Hi Sebastien,<div><br></div><div>I did load testing locally and ran the application through Intellij. The way intellij runs the application falls into "java -cp "all-paths-to-classes-and-dependencies" com.example.MyApplication" category.</div><div><br></div><div>And of course I am aware of Spring Boot 3.2+ releases. The point of my load testing was testing an application with lots of contention on objectmonitors rather than a setup where most of the synchronized blocks have been replaced by ReentrantLock. </div><div><br></div><div>So I would argue that for the mere purpose of testing Loom's new object monitor implementation, and making sure hanging is not happening, Spring boot 2.7.x is a better candidate than 3.2.x. I hope this helps to clarify the testing's goal.</div><div><br></div><div>Kind regards,</div><div>Masoud</div><div><br></div><div> <br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Feb 21, 2024 at 10:04 AM Sebastien Deleuze <<a href="mailto:sebastien.deleuze@broadcom.com" target="_blank">sebastien.deleuze@broadcom.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr">Hi,<div><br></div><div>FYI I will shortly provide dedicated feedback on those object monitor changes with Spring applications.<br><div><br></div><div>Masoud, could you please share how the Spring Boot application you are benchmarking is deployed?</div><div><br></div><div>Executable JAR deployment ("java -jar application.jar") is known to provide sub-optimal performance while serving static resources (with or without virtual threads involved). If executable JAR is currently used, I would advise to follow recommendations from <a href="https://docs.spring.io/spring-boot/docs/current/reference/html/deployment.html#deployment.efficient.unpacking" target="_blank">https://docs.spring.io/spring-boot/docs/current/reference/html/deployment.html#deployment.efficient.unpacking</a> for using a production-ready deployment. If the application is already unpacked, could you please share what variant you are using ("java org.springframework.boot.loader.launch.JarLauncher" versus "java -cp "BOOT-INF/classes:BOOT-INF/lib/*" com.example.MyApplication")?</div><div><br></div><div>For any virtual threads related benchmark, I would also recommend to use the latest Spring Boot 3.2+ release available with "spring.threads.virtual.enabled=true" configured. If you identify areas where some refinements could be made in a typical Spring Boot application, feel free to let me know.</div><div><br></div><div>Best regards,</div><div>Sébastien Deleuze</div></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Sun, Feb 18, 2024 at 11:02 AM Alan Bateman <<a href="mailto:Alan.Bateman@oracle.com" target="_blank">Alan.Bateman@oracle.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">On 17/02/2024 12:32, masoud parvari wrote:<br>
> Thanks Alan for the detailed explanation. This reminds me of Java 21 <br>
> deadlock scenarios when obtaining a lock both outside and inside a <br>
> synchronized block by some number of threads greater than machine <br>
> cores, could potentially cause deadlock.<br>
><br>
> I still have one question though. This deadlock scenario (a burst of <br>
> virtual threads at startup with a mix of class loading (which comes <br>
> with pinning) and resource loading from the same JAR files) is not <br>
> happening on 21 and latest 23-ea. I suspect because Forkjoinpool <br>
> creates more thread to compensate for pinning? Would you please <br>
> shed some light on this?<br>
><br>
<br>
In JDK 21, the two threads doing getResourceAstream (#119 and #123) <br>
would not have released the carrier when they blocked on the monitor in <br>
Zipfile.getEntry.  They pinned their carriers. With the EA builds, they <br>
do release the underlying carrier threads to do other work. This just <br>
means that other scheduled virtual threads get to run and block in <br>
nl.trifork.qti.model.processing.expression.general.BaseValue.<init> with <br>
a native frame on the stack. So with JDK 21, it was possible to exit the <br>
monitor for the ZipFile and #119 or #123 would continue. With the EA <br>
builds, neither can continue as there is no carrier available. This is <br>
not your doing of course. BaseValue.<init> is probably resolving a <br>
reference to a class and this is the call through the VM.<br>
<br>
I think the summary here is that addressing the issue with object <br>
monitors pinning is great but the hoorays may be short lived as the spot <br>
light moves to other cases where carriers are pinned, and specifically <br>
native frames due to resolving references to classes in the constant <br>
pool and the resulting class loading, or class initializers. There are <br>
some ideas around this that may provide some relief on these cases. We <br>
had to shake out issues with object monitors first.<br>
<br>
-Alan<br>
<br>
<br>
<br>
<br>
<br>
</blockquote></div>

<br>
<span style="background-color:rgb(255,255,255)"><font size="2">This electronic communication and the information and any files transmitted with it, or attached to it, are confidential and are intended solely for the use of the individual or entity to whom it is addressed and may contain information that is confidential, legally privileged, protected by privacy laws, or otherwise restricted from disclosure to anyone else. If you are not the intended recipient or the person responsible for delivering the e-mail to the intended recipient, you are hereby notified that any use, copying, distributing, dissemination, forwarding, printing, or copying of this e-mail is strictly prohibited. If you received this e-mail in error, please return the e-mail to the sender, delete it from your computer, and destroy any printed copy of it.</font></span></blockquote></div>
</blockquote></div>

<br>
<span style="background-color:rgb(255,255,255)"><font size="2">This electronic communication and the information and any files transmitted with it, or attached to it, are confidential and are intended solely for the use of the individual or entity to whom it is addressed and may contain information that is confidential, legally privileged, protected by privacy laws, or otherwise restricted from disclosure to anyone else. If you are not the intended recipient or the person responsible for delivering the e-mail to the intended recipient, you are hereby notified that any use, copying, distributing, dissemination, forwarding, printing, or copying of this e-mail is strictly prohibited. If you received this e-mail in error, please return the e-mail to the sender, delete it from your computer, and destroy any printed copy of it.</font></span>