Runtime fixes/enhancements for static JDK work

Alan Bateman Alan.Bateman at oracle.com
Tue Jun 27 13:06:58 UTC 2023


On 27/06/2023 00:46, Jiangli Zhou wrote:
> :
>
> We've already recently integrated some of the static JDK related
> changes, including duplicate symbol fixes and build changes for static
> libraries. The main tracking bug is JDK-8303796 [5] currently. We'd
> like your thoughts and opinions on if a new JEP would be needed/useful
> for the additional runtime fixes/enhancement. The question has been
> previously raised by Mark in JDK-8307858 [6] comments.

As I see it, this patch gets you to the point of creating bin/javastatic 
containing all native code needed for headless (and jpackage-less) use 
on Linux. It's as you say, something that someone working on the JDK 
could use for testing, it's not something that suitable for distribution 
as it's incomplete.

It's probably next steps where a JEP will be important, maybe several 
JEPs depending on far it goes and whether the effort is split into into 
coherent steps. There are many reasons why a JEP (or JEPs) will be 
needed. It's a significant move to produce and consume a self-contained 
static image. Today, the JDK image is zipped up or wrapped in an 
installer for developers to unzip or install. It's a big decision for 
producers of builds as to whether they will publish static images as 
alternative downloads. For developers, or other consumers of builds, 
they it's a hugely significant packaging/deployment option for developers.

A JEP for next steps will also have to answer a lot of questions about 
packaging and the deployment experience. Will a static image include all 
standard + JDK modules, how will be integrate with jlink?   Can 
developers use static image "as is" or do they have to run a tool that 
combines their modular or non-modular application with the static image. 
Is jpackage in this story? There are many topics to discuss here.

A JEP is a great place to capture topics on all the issues that arise 
from moving to a self containing file. Can jpackage or some other tool 
change the user-editable configuration when combining the output from 
the JDK build? What should code do if it re-execs itself with 
${java.home}/bin/java? Can a self-contained image be 
monitored/management when the troubleshooting/other tools don't exist. 
There are many more questions like this that a JEP could answer.

-Alan


More information about the leyden-dev mailing list