<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>