Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
Jump to content

GraalVM

From Wikipedia, the free encyclopedia

This is an old revision of this page, as edited by Jlwoodwa (talk | contribs) at 04:44, 8 July 2023 (Spread: sp). The present address (URL) is a permanent link to this revision, which may differ significantly from the current revision.

GraalVM
Developer(s)Oracle Corporation
Stable release
GraalVM for JDK 22.0.1[1] Edit this on Wikidata / 16 April 2024; 8 months ago (16 April 2024)
Repository
Written inJava
Operating systemLinux, Windows and macOS[2]
PlatformJava Virtual Machine
TypeJava dynamic compiler and runtime
LicenseCommunity Edition: GPLv2[3][4] Enterprise Edition: Trialware
Websitewww.graalvm.org

GraalVM is a Java VM and JDK based on HotSpot/OpenJDK, implemented in Java. It supports additional programming languages and execution modes, like ahead-of-time compilation of Java applications for fast startup and low memory footprint. The first production-ready version, GraalVM 19.0, was released in May 2019.[5] The most recent version is GraalVM GraalVM for JDK 22.0.1[1] Edit this on Wikidata, made available in April 2024.

Major differentiators of GraalVM compared to the base JDK are:

  • GraalVM Compiler, a JIT compiler for Java
  • GraalVM Native Image, allowing the ahead-of-time compilation of Java applications
  • Truffle Language Implementation framework and the GraalVM SDK, to implement additional programming language runtimes
  • LLVM Runtime and JavaScript Runtime

Project goals

  • To improve the performance of Java virtual machine-based languages to match the performance of native languages.[6][7]
  • To reduce the startup time of JVM-based applications by compiling them ahead-of-time with GraalVM Native Image technology.
  • To enable GraalVM integration into the Oracle Database, OpenJDK, Node.js, Android/iOS, and to support similar custom embeddings.
  • To allow freeform mixing of code from any programming language in a single program, billed as "polyglot applications".[6][8]
  • To include an easily extended set of "polyglot programming tools".[6][9]

History

GraalVM has its roots in the Maxine Virtual Machine project at Sun Microsystems Laboratories (now Oracle Labs). The goal was to write a Java virtual machine in Java itself, hoping to free the development from the problems of developing in C++, particularly manual memory management, and benefit from meta-circular optimizations. Upon realizing that writing everything in Java was too ambitious as a first step, the decision was taken to focus on the compiler only and hook it into Hotspot, to reuse as much as possible the Hotspot runtime. The GraalVM compiler was started by manually converting the code of the Hotspot client compiler (named "C1") into Java, replacing the previous Maxine compiler.[10]

Graal was included in HotSpot-based Java VM releases like OpenJDK from Java 9 through 15, in order to support experimental ahead-of-time compilation. The UseJVMCICompiler option also allowed JIT use as a C2 replacement.[11] It was removed in Java 16 as maintaining both the version in the JDK and the standalone GraalVM release caused duplicate effort.[12] A similar functionality to create native executables from Java projects is provided by the native-image tool of standalone GraalVM releases.

Releases

GraalVM is available as Community Edition for an open-source license and as Oracle GraalVM Enterprise Edition accessible by accepting the "OTN License Agreement Oracle GraalVM Enterprise Edition Including License for Early Adopter Versions".[13] Oracle Corporation announced the release of Oracle GraalVM Enterprise Edition on 8 May 2019.[14] GraalVM can substitute a default JDK on Linux and macOS platforms on x86 64-bit systems.

GraalVM 22

GraalVM 22.3.0 GraalVM 22.3.0 was released in October 2022.

GraalVM 22.2.0 GraalVM 22.2.0 was released in July 2022.

GraalVM 22.1.0 GraalVM 22.1.0 was released in April 2022.[15]

GraalVM 22.0.0 GraalVM 22.0.0 was released in January 2022.

GraalVM 21

GraalVM 20

GraalVM 20.3.0

GraalVM 20.3.0 was released in November 2020.[16] It was marked as the first LTS enterprise version of GraalVM and as the final release for 2020. This version supports code sharing in the GraalVM LLVM runtime, allowing the AST and compiled code of common bitcode libraries to be shared between multiple contexts within a single engine.

GraalVM 20.1.0

GraalVM 20.1.0 was released in May 2020.[17] It included several improvement for many of the components. Besides performance improvements, usability fixes for native-image were published. The JavaScript engine supports all ECMAScript 2020 mode features by default. The regular expression engine (TRegex) used by JavaScript and Python supports all expressions now. Ruby (TruffleRuby) improved in compatibility with native gems.

GraalVM 20.0.0

GraalVM 20.0.0 was released in February 2020.[18] It improved in its Windows support, brought an enhanced native-image tool and improved the tooling support, among many detailed changes in the compiler and supported languages.

GraalVM 19

GraalVM 19.0.0

The support on Windows is currently under development and released as an early adopter functionality in GraalVM 19.0.

GraalVM 19.0 is based on top of JDK version 8u212.

Components

The GraalVM compiler is shipped with the components of a normal Java virtual machine (OpenJDK). Additional components are included in GraalVM to support new execution modes (GraalVM Native Image) or programming languages (LLVM runtime, GraalVM JavaScript as a potential replacement to the deprecated Nashorn engine, TRegex as a regular expression engine).

Birds-eye view on GraalVM 22.3.2 architecture

GraalVM Compiler

The GraalVM Compiler is a modern Java just-in-time compiler. It complements or replaces the existing compilers (C1/C2 in HotSpot). In contrast to those existing compilers, the GraalVM compiler is written in modular, maintainable and extendable fashion in Java itself.

It is released under GPL version 2 with the classpath exception.

GraalVM Native Image

GraalVM Native Image is an ahead-of-time compilation technology that produces executable binaries of class files.[19] It is released as an early adopter plugin, which means it is production-ready but may include backport incompatible updates in the future releases.

This functionality supports JVM-based languages, but can optionally execute dynamic languages, developed on top of GraalVM with Truffle framework. The executable file does not run on a JVM and uses necessary runtime components such as thread scheduling or GC from a minimal bespoke virtual machine called Substrate VM. Since the resulting native binary includes application classes, JDK dependencies and libraries already, the startup and execution time reduces significantly.

GraalVM Native Image is officially supported by the Fn, Gluon, Helidon, Micronaut, Picocli, Quarkus, Vert.x and Spring Boot Java frameworks.[20][21] In September 2016, Oracle detailed plans to add ahead-of-time compilation to the OpenJDK using the GraalVM compiler for Java 9.[22][23] This proposal, tracked by the JEP 295: Ahead-of-Time Compilation, was included in Java 9.[24] The experimental use of GraalVM as a just-in-time compiler was added for the Linux x86-64 platform for Java 10.[25]

In JDK releases 9 to 15, the jaotc command creates a Native Image.[26] The experimental -XX:+EnableJVMCIProduct flag enables the use of Graal JIT.[27] The functionality is since available in the native-image component of standalone GraalVM releases.[28]

Truffle Language Implementation Framework

In association with GraalVM, Oracle Labs developed a language abstract syntax tree interpreter called "Truffle" which would allow it to implement languages on top of the GraalVM.[29][30] Many languages have been implemented in Truffle, including a C interpreter claiming to be about as fast as GCC and Clang.[31]

The Truffle framework and its dependent part, GraalVM SDK, are released under the Universal Permissive License, version 1.0, to encourage use of the framework for projects which do not want to be bound by the copyright or other parent rights.

Instrumentation-based Tool Support

A major advantage of the GraalVM ecosystem is language-agnostic, fully dynamic instrumentation support built-in directly into the VM runtime. Execution events can be captured by API clients with overhead that is extremely low in fully optimized code.[32][33]

The core GraalVM installation provides a language-agnostic debugger, profiler, heap viewer, and others based on instrumentation and other VM support.[9] GraalVM also includes a backend implementation of the Chrome Inspector remote debugging protocol.[34] Although designed originally for JavaScript debugging, it can be used to debug all GraalVM languages from a browser.

Polyglot programming

One of the advantages of GraalVM is the possibility to write "polyglot" applications.[8] This means that a developer has the possibility to integrate multiple programming languages inside of the same source code, granting him the characteristic advantages of every language. This is possible thanks to the Truffle Language Implementation Framework.[29]

Working with arrays

Starting from the implementation of one of the languages available in GraalVM, it is possible to declare, inside of the source code, arrays coming from different programming languages. The interaction between the "local" language and the "external" one is automatically handled by Truffle. In the following code snippets, taken from the reference manual of GraalVM[8], it is possible to observe how to utilise polyglot programming.

Creation of an array in R from JavaScript:

var array = Polyglot.eval("R", "c(1,2,42,4)")
console.log(array[2]);

Creation of an array in Python from Java:

import org.graalvm.polyglot.*;

class Polyglot {
    public static void main(String[] args) {
        Context context = Context.newBuilder().allowIO(true).build();
        Value array = context.eval("python", "[1,2,42,4]");
        int result = array.getArrayElement(2).asInt();
        System.out.println(result);
    }
}

Creation of a JavaScript array from Python:

import polyglot
array = polyglot.eval(language="js", string="[1,2,42,4]")
print(array[2])

Invoking functions

Always thanks to the interoperability layer offered by Truffle, it is possible to call functions written in different languages from the same application, for example, in Java:

try (Context context = Context.create()) {
    Value function = context.eval("python", "lambda x: x + 1");
    assert function.canExecute();
    int x = function.execute(41).asInt();
    assert x == 42;
}

In this code snippet we are creating a function defined in Python.[35] This function will increment of a unit the value provided and then return it to the host language. From Java, for security purposes, we will ask first if the variable function can be execute via the canExecute() call, and then we will invoke the function with the execute() call.

Language and Runtime Support

GraalVM is written in and for the Java ecosystem. It can execute applications written in all languages that compile to the Java bytecode format, e.g. Java, Scala, Kotlin, and more.

Based on Truffle Language Implementation framework additional languages can be supported in GraalVM.

Support for additional languages can be implemented by users of GraalVM. Some notable third-party language implementations are grCuda,[43] SOMns,[44] TruffleSqueak,[45][46] and Yona.[47]

Spread

GraalVM is used in various industrial scenarios:

  • Disney[48]: utilise the native-image technology to reduce the cold-start time of some of its AWS microservices
  • Facebook[49]: use GraalVM to speed-up Apache Spark workloads reducing the memory footprint and the utilisation of the CPU
  • Twitter[50]: accelerate some of the microservices of the platform
  • Goldman Sach[51]: the international investment bank rewrote its internal programming language Slang via the Truffle framework of GraalVM

References

  1. ^ a b "GraalVM for JDK 21". Retrieved 21 June 2024.
  2. ^ "Downloads".
  3. ^ "GraalVM FAQ". Archived from the original on 2020-04-13. Retrieved 2018-04-25.
  4. ^ "graal/README.md". GitHub. Retrieved 2018-04-25.
  5. ^ "For Building Programs That Run Faster Anywhere: Oracle GraalVM Enterprise Edition". Oracle Corporation. Retrieved 2022-01-21.
  6. ^ a b c "Why GraalVM". Retrieved 2018-04-25.
  7. ^ "Graal : Un compilateur dynamique pour Java". lemondeinformatique.fr. 2012-02-13. Retrieved 2013-08-23.
  8. ^ a b c "Reference Manual for Polyglot Applications". Archived from the original on 2020-10-23. Retrieved 2018-04-25.
  9. ^ a b "GraalVM Debugging and Monitoring Tools". www.graalvm.org. Archived from the original on 2019-04-25. Retrieved 2019-04-08. GraalVM provides a set of tools for developers, integrators, and IT administrators to debug and monitor GraalVM and deployed applications.
  10. ^ ""Meta-Circularity is Near", GraalVM, Truffle--airhacks.fm podcast : Adam Bien's Weblog". Archived from the original on 2020-05-29.
  11. ^ "OpenJDK: Graal".
  12. ^ "[JDK-8255616] Removal of experimental features AOT and Graal JIT". bugs.openjdk.java.net. Retrieved 2021-03-13.
  13. ^ https://www.oracle.com/technetwork/licenses/graalvm-otn-license-5486575.html [bare URL]
  14. ^ "GraalVM 19.3: Announcing GraalVM 19.3 with JDK 11 Support". Oracle Corporation. 20 November 2019. Retrieved 2019-11-25.
  15. ^ "GraalVM Release Notes 22.1.0". 2022-04-26. Retrieved 2022-04-26.
  16. ^ Šelajev, Oleg (2020-11-20). "GraalVM 20.3 is available". Medium. Retrieved 2020-12-31.
  17. ^ GraalVM 20.1
  18. ^ A look at GraalVM 20.0: better Windows support, better Native Images, better tooling
  19. ^ "Native Images". www.graalvm.org. Archived from the original on 2018-04-20.
  20. ^ "GraalVM Open Source Ecosystem". Oracle Corporation. Retrieved 2019-09-11.
  21. ^ "Spring Native Image documentation". Spring Framework. Retrieved 2021-10-26.
  22. ^ "Ahead-of-Time (AOT) Compilation May Come to OpenJDK HotSpot in Java 9". InfoQ.com. 2016-10-01. Retrieved 2016-10-06. AOT brings about a new tool called 'jaotc' which uses Graal as the backend (to generate code)
  23. ^ Vladimir Kozlov (2016-09-14). "JDK-8166089: Ahead-of-Time Compilation". Oracle Corporation. Retrieved 2016-10-06. Compile an application's Java classes to native code prior to launching the virtual machine.
  24. ^ Vladimir Kozlov (2016-10-13). "JEP 295: Ahead-of-Time Compilation". Oracle Corporation. Retrieved 2016-10-13. Compile Java classes to native code prior to launching the virtual machine.
  25. ^ Vladimir Kozlov (2017-10-20). "JEP 317: Experimental Java-Based JIT Compiler". Oracle Corporation. Retrieved 2018-01-21. JEP 317: Experimental Java-Based JIT Compiler
  26. ^ "OpenJDK: Graal". openjdk.java.net.
  27. ^ "[JDK-8232118] Add JVM option to enable JVMCI compilers in product mode". bugs.openjdk.java.net.
  28. ^ "GraalVM: Reference Manual: Native Image". graalvm.org.
  29. ^ a b "Truffle: A Self-Optimizing Runtime System" (PDF). Oracle Corporation. Retrieved 2013-08-23.
  30. ^ "Truffle served in a Holy Graal: Graal and Truffle for polyglot language interpretation on the JVM". 2017-12-05. Retrieved 2018-04-25.
  31. ^ "Truffle: Languages and Material". Gist.
  32. ^ Van De Vanter, Michael; Seaton, Chris; Haupt, Michael; Humer, Christian; Würthinger, Thomas (March 9, 2018). "Fast, Flexible, Polyglot Instrumentation Support for Debuggers and other Tools". The Art, Science, and Engineering of Programming. 2 (3, Article 14): 30. arXiv:1803.10201. doi:10.22152/programming-journal.org/2018/2/14. S2CID 4382172.
  33. ^ "Getting started with Instruments in GraalVM". www.graalvm.org. Retrieved 2019-04-08. Truffle instruments can track very fine-grained VM-level runtime events to profile, inspect, and analyze the runtime behavior of applications running on GraalVM.
  34. ^ "Chrome DevTools". developers.google.com. Retrieved 2019-04-08. Chrome DevTools is a set of web developer tools built directly into the Google Chrome browser. DevTools can help you edit pages on-the-fly and diagnose problems quickly, which ultimately helps you build better websites, faster.
  35. ^ "Embedding Languages". www.graalvm.org. Retrieved 2023-07-05.
  36. ^ GraalVM JavaScript github repository
  37. ^ TruffleRuby github repository
  38. ^ GraalVM FastR github repository
  39. ^ GraalPython github repository
  40. ^ GraalVM LLVM Runtime github repository
  41. ^ "GraalWasm github repository". GitHub.
  42. ^ Prokopec, Aleksandar (2019-12-02). "Announcing GraalWasm — a WebAssembly engine in GraalVM". Medium. Retrieved 2020-01-15.
  43. ^ grCuda GitHub repository
  44. ^ SOMns GitHub repository
  45. ^ TruffleSqueak GitHub repository
  46. ^ Niephaus, Fabio; Felgentreff, Tim; Hirschfeld, Robert (2019). "GraalSqueak: Toward a Smalltalk-based Tooling Platform for Polyglot Programming". Proceedings of the 16th ACM SIGPLAN International Conference on Managed Programming Languages and Runtimes - MPLR 2019. ACM Digital Library. pp. 14–26. doi:10.1145/3357390.3361024. ISBN 9781450369770. S2CID 204728643. Retrieved 2020-11-08.
  47. ^ Yona Language
  48. ^ "Improving Developer Productivity at Disney with Serverless and Open Source | AWS Open Source Blog". aws.amazon.com. 2022-11-09. Retrieved 2023-07-05.
  49. ^ "GraalVM at Facebook".
  50. ^ "How Oracle GraalVM Supercharged Twitter's Microservices Platform" (PDF).
  51. ^ "One VM to Rule Them All? Lessons Learned with GraalVM | Curry On London! 2019". www.curry-on.org. Retrieved 2023-07-05.