-
Notifications
You must be signed in to change notification settings - Fork 35
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
GraalVM native-image support #47
Comments
If I did this I'd want it to be really easy, no setting of GRAAL_HOME or whatever. It should just be automatic. |
https://www.graalvm.org/sdk/javadoc/ is this what we are after? The native image parts? Not sure. |
I didn't actually go as far as checking if there is a Java API available. If such exists, it would be a good match to help with being "automatic" :) |
https://medium.com/graalvm/simplifying-native-image-generation-with-maven-plugin-and-embeddable-configuration-d5b283b92f57 suggests the maven plugin is doing it |
Ahaa!, that set's a target for us then :) |
I have to admit not doing proper background research as there are atleast two tools, https://github.com/luchiniatwork/cambada and https://github.com/taylorwood/clj.native-image, that operate in this area. If native-image has a library api (and is available as a dependency), it would set pack apart from the other tools. |
This looks a bit bad 😬 https://github.com/oracle/graal/blob/master/substratevm/src/native-image-maven-plugin/src/main/java/com/oracle/substratevm/NativeImageMojo.java#L166:
The "Simplifying native-image generation with Maven plugin and embeddable configuration" post states:
So I guess it relies on the |
There's also this following that:
|
Seems like JVMCI is a draft proposal, and only graal is building open jdk with it for now. (These are both statements that need confirming). I would not be opposed to downloading graalvm into a cache directory and shelling out to that native-image if graalvm cannot be found via the normal methods. |
jvmci doesn't exist in my oracle jdk install.. |
Seems that from 19.00 onwards (see github releases page), native-image was extracted from the Graal distribution and is available as a jar, but it is not independent and relies on the Graal distribution. 300MB of Graal seems like quite a drink in the cache, but might still be worth a try for better usability :) I wonder what is the minimum of deps that the utility actually needs from inside graal... |
It's a big cache, but you will need it downloaded either way. Pack can do it for you, or you can do it and specify the location. The cache would be a fallback. Some kind of garbage collection seems worthwhile though. The idea of tree shaking graal sounds interesting :p. |
Thinking out loud: Maybe we could check for latest release of Graal and even prompt to upgrade to it. A I don't know if |
My thinking was something along the lines of checking for GRAALVM_HOME, checking if JAVA_HOME contains https://github.com/soc/directories-jvm I'd probably use this for the cache location, because I'm a sucker for compliance. |
TIL directories-jvm :) This sounds like good reasoning to me. |
Doodling thoughts here: It occurred to me that maybe a native-image based AWS Lambda custom runtime could be an spot open in the Clojure cloud tooling :) Pack already has a command for packaging a Lambda for the JVM runtime, but the custom runtime with native-image/SubtrateVM would have better startup time. We could also take care of things like bundling libsunec.so, which would be quite convenient for the user (maybe do deploy also). |
OpenJDK11 does support JVMCI behind a flag:
This might be good enough (with a fallback env var for JDK 8 for users who really need it) |
Hmm, so in the subtratevm readme, it says
So how does one get this program, is there a maven library? Seems that I haven't studied this enough :) |
The graal team have a custom openjdk8 build with JVMCI in. I doubt the patch will be made upstream by oracle. It might be available in zulu or something though.
7 Dec 2019 16:59:31 Kimmo Koskinen <[email protected]>:
…
Hmm, so in the subtratevm readme, it says
>
> Native image generation is performed by a Java program that runs on JDK 8 with JVMCI.
>
So how does one get this program, is there a maven library? Seems that I haven't studied this enough :)
—
You are receiving this because you commented.
Reply to this email directly, view it on GitHub [#47?email_source=notifications&email_token=ABO2DWTWURRPS64BYMFKZG3QXPI7FA5CNFSM4IFWRJOKYY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOEGGK63Q#issuecomment-562868078] , or unsubscribe [https://github.com/notifications/unsubscribe-auth/ABO2DWTBCHKVR4VKACT6BSLQXPI7FANCNFSM4IFWRJOA] . [https://github.com/notifications/beacon/ABO2DWS4NCQRU7J4XCAY3X3QXPI7FA5CNFSM4IFWRJOKYY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOEGGK63Q.gif]
|
The JVMCI approach was later removed, unfortunately. oracle/graal@1ee1262 |
It appeared to work by using an artifact like https://mvnrepository.com/artifact/org.graalvm.nativeimage/svm-hosted-native-windows-amd64/22.1.0 and untarring it to a target directory... This might still be viable. The release seems recent still. We already have TDA on the classpath so fetching the correct tar.gz shouldn't be a problem. |
One interesting idea might be to leverage the fact that most devs have docker installed, even if they don't have graalvm installed. It would also make it easier to have a reproducible version of native-image that's used per project. |
This would allow building to native executable. I'm thinking that we could add a namespace for calling the
native-image
tool, with suitable defaults (example from jet).The text was updated successfully, but these errors were encountered: