Spring team feedback on Leyden-premain optimizations

Sebastien Deleuze sebastien.deleuze at broadcom.com
Fri Jan 19 10:47:47 UTC 2024


Hi,

I would like to share the Spring team feedback on Leyden-premain
optimizations.

I have updated my spring-boot-leyden-demo repository [1] to leverage the
new Leyden 1 step workflow [2] that is much simpler to use than the
previous 5 steps workflow. It is great to see that we can reuse the same
`-Dspring.context.exit=onRefresh` property introduced by Spring Framework
6.1 for Class Data Sharing [3] with this new Class Data Store arrangement.

I am not sure if all optimizations are enabled yet, but the data points on
my MacBook with Spring Petclinic are already promising, and pretty close to
what we observed with the 5 steps workflow:
 - Executable JAR: 1.55s
 - Unpacked: 1.26s
 - Unpacked + Premain: 0.80s
 - Unpacked + Premain + Spring AOT: 0.56s

A few remarks:
 - We currently observe various warnings [4]
 - We have to use `-XX:CachedCodeMaxSize` in order to have cached code
generation with the "Unpacked + Premain" variant since its generates a
cached code of 12M (more than current 10M default limit)
 - We plan to do more benchmarks on cheap production servers (1 CPU 2G RAM
and 2 CPU 4G RAM)

I have for now only measured the startup time improvements, not yet the
warm up time improvements. I would be interested to know if the Leyden
premain branch already provides warm up improvements worth benchmarking
with Spring applications.

Best regards,
Sébastien Deleuze

[1] https://github.com/sdeleuze/spring-boot-leyden-demo
[2]
https://github.com/openjdk/leyden/tree/premain/test/hotspot/jtreg/premain/javac_new_workflow
[3]
https://spring.io/blog/2023/12/04/cds-with-spring-framework-6-1/#initial-cds-support-introduced-in-spring-framework-61
[4] https://gist.github.com/sdeleuze/8d442f9e85b069be0a5b24f3454d39a8

-- 
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.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mail.openjdk.org/pipermail/leyden-dev/attachments/20240119/0432fe60/attachment.htm>


More information about the leyden-dev mailing list