<div dir="ltr"><div dir="ltr">On Thu, Feb 13, 2025 at 12:36 PM <<a href="mailto:ioi.lam@oracle.com">ioi.lam@oracle.com</a>> wrote:</div><div class="gmail_quote gmail_quote_container"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><u></u>
<div>
<p>Which build of JDK 24 (or mainline) are you using? There's a
recent change that turns on -XX:+AOTClassLinking automatically to
take advantage of all JEP 483 optimizations (including the
AOT-linking of lambdas)<br>
</p>
<p><a href="https://bugs.openjdk.org/browse/JDK-8348752" target="_blank">https://bugs.openjdk.org/browse/JDK-8348752</a><br>
</p>
<p>If you're using an older JDK 24 build (earlier than JDK 24-b35),
you might need to add -XX:+AOTClassLinking explicitly.</p>
<p>A good way for checking is with -Xlog:cds,class+load and see how
many classes you are loading from CDS vs dynamically parsed.<br></p></div></blockquote><div class="gmail_quote gmail_quote_container">I'm running the RC from last week:</div><div class="gmail_quote gmail_quote_container"><br></div>$ java -version<br>openjdk version "24" 2025-03-18<br>OpenJDK Runtime Environment (build 24+36-3646)<br>OpenJDK 64-Bit Server VM (build 24+36-3646, mixed mode, sharing)<br><div><br></div><div>But perhaps the fix I need is not in this build? I ran the record and create steps again with -XX:+AOTClassLinking and performance wasn't substantially changed.</div><div><br></div><div>I do see lines like this, though, when I enable logging:</div><div><br></div><div>[0.895s][info][class,load] org.jruby.util.io.FilenoUtil$ReflectiveAccess$$Lambda/0x8000004ea source: shared objects file<br>[0.895s][info][class,load] org.jruby.util.io.FilenoUtil$ReflectiveAccess$$Lambda/0x8000004eb source: shared objects file</div><div><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><p>
</p>
<p>Thanks</p>
<p>- Ioi<br>
</p>
<div>On 2/13/25 7:12 AM, Charles Oliver
Nutter wrote:<br>
</div>
<blockquote type="cite">
<div dir="ltr">
<div>I figured folks here would be interested to see this
experiment using AOTCache with JRuby.</div>
<div><br>
</div>
<div><a href="https://gist.github.com/headius/1a5cfbc91ed8bacd194f1c592a90c275" target="_blank">https://gist.github.com/headius/1a5cfbc91ed8bacd194f1c592a90c275</a></div>
<div><br>
</div>
<div>I just test the 'hello world' scenario that represents our
baseline startup, but AOT caching manages to beat the
automatic AppCDS startup by a bit. More/better training might
help here I'm guessing?</div>
<div><br>
</div>
<div>This is from the JRuby 10 branch (10-dev) on <a href="https://github.com/jruby/jruby.git" target="_blank">https://github.com/jruby/jruby.git</a>
if anyone wants to play with it. Just run `./mvnw` and then
`bin/ruby` will work. We recently added support for
AutoCreateSharedArchive so it will use CDS by default. Pass
--nocache to disable that behavior.</div>
<div><br>
</div>
<div>
<div dir="ltr" class="gmail_signature">
<div dir="ltr"><b>Charles Oliver Nutter</b>
<div><i>Architect and Technologist</i></div>
<div>Headius Enterprises</div>
<a href="https://www.headius.com" target="_blank">https://www.headius.com</a>
<div>
<div><a href="mailto:headius@headius.com" target="_blank">headius@headius.com</a></div>
</div>
</div>
</div>
</div>
</div>
</blockquote>
</div>
</blockquote></div></div>