<div dir="ltr"><div dir="ltr">On Wed, Feb 12, 2025 at 4:22 PM Charles Oliver Nutter <<a href="mailto:headius@headius.com">headius@headius.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"><div dir="ltr"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div><p>Have you tried the -XX:+AutoCreateSharedArchive flag? It should
recreate the dynamic archive if you have updated the app's JAR
files or updated to a new JDK.<br></p></div></blockquote><div>This is definitely what we want for the JRuby launcher! I've integrated it into the launcher and it seems to work well (my log redirects must still be included to silence CDS warnings, though):</div></div></div></blockquote><div><br></div><div>I am seeing two peculiar warnings in the log file while using this flag:</div><div><br></div>[0.001s][info][cds] optimized module handling: disabled due to incompatible property: jdk.module.path=/Users/headius/work/jruby/lib/jruby.jar</div><div class="gmail_quote gmail_quote_container"><br></div><div class="gmail_quote gmail_quote_container">This is not a property I'm setting. The full command line for this JRuby execution is here:</div><div class="gmail_quote gmail_quote_container"><br></div><div class="gmail_quote gmail_quote_container">/Library/Java/JavaVirtualMachines/zulu-21.jdk/Contents/Home/bin/java @/Users/headius/work/jruby/bin/.jruby.java_opts @/Users/headius/work/jruby/bin/.jruby.module_opts -Xss2048k -XX:+AutoCreateSharedArchive -XX:SharedArchiveFile=/Users/headius/work/jruby/lib/jruby.jsa -Xlog:cds=off -Xlog:cds+dynamic=off -Djffi.boot.library.path=/Users/headius/work/jruby/lib/jni -Djava.security.egd=file:/dev/urandom --module-path /Users/headius/work/jruby/lib/jruby.jar -classpath : -Djruby.home=/Users/headius/work/jruby -Djruby.lib=/Users/headius/work/jruby/lib -Djruby.script=jruby -Djruby.shell=/bin/sh org.jruby.Main -e 1</div><div class="gmail_quote gmail_quote_container"><br></div><div class="gmail_quote gmail_quote_container">The java_opts file is empty and the module_opts file just has some add-opens we need.</div><div class="gmail_quote gmail_quote_container"><br>[0.001s][warning][cds] AutoCreateSharedArchive is ignored because /Users/headius/work/jruby/lib/jruby.jsa is a static archive<br><div><br></div><div>I have no idea what this means. Once I get in this state it complains every startup and will also refuse to overwrite the "bad" jsa file. I had thought that it would overwrite the file if it could not use it, so I don't have to manually separate CDS archives from different JDKs... did I misunderstand?</div></div></div>