How is GraalVM licensed?
GraalVM is distributed as Community and Enterprise editions.
GraalVM Community Edition is open source software built from the sources available on GitHub and distributed under version 2 of the GNU General Public License with the “Classpath” Exception, which are the same terms as for Java. We also recommend checking the licenses of the individual GraalVM components (which are generally derivative of the license of a particular language). GraalVM Community is free to use for any purpose and comes with no strings attached, but also no guarantees or support.
Oracle GraalVM Enterprise Edition is licensed under the Oracle Technology Network License Agreement for GraalVM Enterprise Edition for testing, evaluation, or for developing non-production applications.
For production use, GraalVM Enterprise is available under the Oracle Java SE Subscription Licensing and Support terms. Subscribers to Oracle Java SE Subscription and Oracle Java SE Desktop Subscription are entitled to use GraalVM Enterprise at no additional cost. Read more here.
What does the GraalVM Enterprise subscription include?
The Oracle Java SE Subscription provides licensing and support for GraalVM Enterprise use on premises, and includes:
- Oracle premier support 24x7 by the Oracle GraalVM team
- Access to My Oracle Support (MOS)
- Java SE Subscription or Java Desktop Subscription at no extra cost
- Improved performance and security over GraalVM Community (see GraalVM Enterprise Announcement)
For Oracle Cloud customers, GraalVM Enterprise is included in the Oracle Cloud subscription.
Where should bugs, security issues, or enhancement requests be reported?
Any security vulnerabilities in either GraalVM Community or GraalVM Enterprise should only be reported via email to email@example.com. Please consult our Reporting Vulnerabilities guide for more information on reporting security vulnerabilities. Do not report security issues on GitHub Issues.
How do I contribute to GraalVM?
We welcome contributions to GraalVM from the community and are thankful for past contributions both big and small. We are happy to accept pull requests at GitHub Pulls. We require contributors to sign the Oracle Contributor Agreement.
How can I receive updates about GraalVM?
We maintain three mailing lists:
- firstname.lastname@example.org – a low traffic announcement list used by the project maintainers;
- email@example.com – an open source user mailing list for general questions and discussions;
- firstname.lastname@example.org – a list for contributors and language implementors.
How do I get support updates?
What is the “readiness” level of GraalVM Windows support?
GraalVM builds for Windows, including all components, are experimental.
The Windows distribution includes the JDK with the GraalVM compiler enabled, the functional
(e.g., Chrome inspector based debugger, Profiler, etc.).
GraalVM Native Image component needs to be installed with
gu as with other distributions.
Can I run my existing application with GraalVM?
What makes GraalVM a true ‘polyglot’ VM?
GraalVM can not only run individual languages with competitive performance, it also enables high-performance language interoperability. Languages can access each other’s data structures and call each other’s methods. We avoid costly conversions of data structures and instead allow data structures to be shared between languages. Our tooling is built in language-agnostic ways to unify tasks like debugging or profiling. This simplifies deployment and configuration of the runtime environment. Important VM components like the just-in-time-compiler and garbage collector are all fully shared across all languages.
What does it mean to run any language ‘anywhere’?
GraalVM can run embedded in OpenJDK, Oracle JDK or Node.js platforms, standalone, or embedded in data stores like the Oracle Database. In all scenarios, the same underlying compilation and language execution technology runs in-process and with direct access to data structures of the surrounding system. The separation of logical and physical data layout is a first class principle for GraalVM and enables flexible use of data structures without marshalling costs. We encourage the embedding of GraalVM in other projects and publish APIs for that purpose. We envision a future where high-performance and standardized language execution technology is available without the need for provisioning separate VM deployments.
Can I use GraalVM with microservices frameworks?
GraalVM can run any Java microservices framework. Several Java microservices frameworks have already accepted the GraalVM Native Image technology as a platform. Examples include: Micronaut, Spring, Helidon, Quarkus. For these frameworks Native Image significantly reduces the startup time and runtime memory requirements.
Can GraalVM run Spring applications?
GraalVM can run Spring applications, compiled with OpenJDK, OracleJDK or other JVMs. Here is a Spring application example that not only runs on GraalVM, but also applies the R language to visualize a plot of the data, using GraalVM polyglot capabilities.
Spring Framework support of Native Image is under active development. The Spring Native project provides an incubating support for compiling Spring applications to native executables using GraalVM Native Image, in order to provide a native deployment option designed to be packaged in lightweight containers. In practice, the target is to support a Spring application (typically a Spring Boot one), unmodified, with GraalVM Native Image.
What is the status of IDE integration?
What are existing real-world production deployments of GraalVM?
Several production deployments of GraalVM exist today. For example, Christian Thalinger from Twitter describes the production deployment of GraalVM at Twitter, how it can help save money via improved performance in his interview Accelerating Processing at Twitter , and how they save money using GraalVM. See others listed in the Use Cases section on GraalVM’s home page. We thank early adopters of our technology who give us feedback on the project and help us develop new features.