Book Image

Supercharge Your Applications with GraalVM

By : A B Vijay Kumar
Book Image

Supercharge Your Applications with GraalVM

By: A B Vijay Kumar

Overview of this book

GraalVM is a universal virtual machine that allows programmers to compile and run applications written in both JVM and non-JVM languages. It improves the performance and efficiency of applications, making it an ideal companion for cloud-native or microservices-based applications. This book is a hands-on guide, with step-by-step instructions on how to work with GraalVM. Starting with a quick introduction to the GraalVM architecture and how things work under the hood, you'll discover the performance benefits of running your Java applications on GraalVM. You'll then learn how to create native images and understand how AOT (ahead-of-time) can improve application performance significantly. The book covers examples of building polyglot applications that will help you explore the interoperability between languages running on the same VM. You'll also see how you can use the Truffle framework to implement any language of your choice to run optimally on GraalVM. By the end of this book, you'll not only have learned how GraalVM is beneficial in cloud-native and microservices development but also how to leverage its capabilities to create high-performing polyglot applications.
Table of Contents (17 chapters)
1
Section 1: The Evolution of JVM
4
Section 2: Getting Up and Running with GraalVM – Architecture and Implementation
8
Section 3: Polyglot with Graal
13
Section 4: Microservices with Graal

What this book covers

Chapter 1, Evolution of Java Virtual Machine, walks through the evolution of JVM and how it optimized the interpreter and compiler. It will walk through C1 and C2 compilers, and the kind of code optimizations that JVM performs to run Java programs faster.

Chapter 2, JIT, HotSpot, and GraalJIT, takes a deep dive into how JIT compilers and Java HotSpot work and how JVM optimizes code at runtime.

Chapter 3, GraalVM Architecture, provides an architecture overview of Graal and the various architecture components. The chapter goes into details on how GraalVM works and how it provides a single VM for multiple language implementations. This chapter also covers the optimizations GraalVM brings on top of standard JVM.

Chapter 4, Graal Just-In-Time Compiler, talks about the JIT compilation option of GraalVM. It goes through the various optimizations the Graal JIT compiler performs in detail. This is followed by a hands-on tutorial to use various compiler options to optimize the execution.

Chapter 5, Graal Ahead-of-Time Compiler and Native Image, is a hands-on tutorial that walks through how to build native images and optimize and run these images with profile-guided optimization techniques.

Chapter 6, Truffle for Multi-language (Polyglot) support, introduces the Truffle polyglot interoperability capabilities and high-level framework components. It also covers how data can be transferred between applications that are written in different languages that are running on GraalVM.

Chapter 7, GraalVM Polyglot – JavaScript and Node.js, introduces the JavaScript and NodeJs. This is followed by a tutorial on how to use the Polyglot API for interoperability to interoperate between an example JavaScript and NodeJS application and a Python application.

Chapter 8, GraalVM Polyglot – Java on Truffle, Python, and R, introduces Python, R, and Java on Truffle (Espresso). This is followed by a tutorial on how to use the Polyglot API for interoperability between various languages.

Chapter 9, GraalVM Polyglot – LLVM, Ruby, and WASM, introduces JavaScript and Node.js. This is followed by a tutorial on how to use the Polyglot API to interoperate between an example JavaScript/Node.js applications.

Chapter 10, Microservices Architecture with GraalVM, covers the modern microservices architecture and how new frameworks such as Quarkus and Micronaut implement Graal for the most optimum microservices architecture.