Join Azul and industry-leading Java luminaries for an engaging FREE virtual event celebrating 30 years of Java! 
99 Days
:
08 Hours
:
56 Minutes
:
05 Seconds
Register
Support

Coordinated Restore at Checkpoint (CRaC)

Instantly start Java apps at optimal speed.

Get CRaCing with Your Favorite Framework 

“CRaC has generated immense interest among the Java developer community and provides a compelling, resource-efficient approach for improving startup and warmup times.”

— Sergio del Amo, Micronaut Product Development Lead

“Project CRaC’s checkpoint restore approach is very promising for the immediate startup of Spring applications on the JVM. Our collaboration with Azul delivered some great initial results already.”

— Juergen Hoeller, project lead and co-founder of the Spring Framework project

A Brief History of CRaC

Azul initiated the OpenJDK CRaC project because we know how important it will be for the entire ecosystem for Java applications to start instantaneously and at full speed. Developers from open-source projects like Micronaut and Quarkus have added support for CRaC, and Azul released JDK 17 Linux x84 64-bit with CRaC support as part of the April 2023 quarterly update. Developers can now deploy applications using CRaC in production with confidence that the JDK will be continuously updated.

CRaC FAQ 

Why is CRaC called CRaC?

CRaC is an acronym. It stands for Coordinated Restore at Checkpoint. The CRaC Java API allows for the coordination of resources during checkpoint and restore operations.

How does CRaC help exactly?

CRaC Java API helps to coordinate JDK and application resources with the checkpoint/restore mechanism.
It allows you to close files and connections, dump cache before checkpoint and reopen/recover everything when the application is restored from the image.

How do I get started with it?

You can get started by downloading Azul Zulu builds of OpenJDK with CRaC support and reading the CRaC documentation. This is a build created by Azul and released as a free-to-use community edition of Azul Zulu Builds of OpenJDK. The build is generally available build and will continue to be updated by Azul. Commercial support is also available with Azul Platform Core.

How much does it cost?

CRaC is an open-source project under OpenJDK. Like OpenJDK, CRaC is free to use.

Where can I get answers if I have questions?

A great place to get answers for CRaC questions is to join the Foojay.io community. If you are an Azul customer, you can also connect with a support engineer.

Can I use CRaC with my applications in containerized environments?

Yes, you can. See the CRaC documentation for more details.

How big are the checkpoint files?

The size of the checkpoint files depends on the size of the heap that you use in your setup. You can think about the checkpoint like a heapdump. Bigger heap means bigger files.

Can I checkpoint off-heap memory?

Yes, that is possible because everything is bound to the Linux session using its PID (Process ID), which also includes off-heap memory.

Can I run CRaC on Mac or Windows?

Currently, Azul Zulu Builds of OpenJDK with CRaC support are available only on Linux. We are considering future implementations.

You can develop your applications and libraries for CRaC on any operating system using the library available at Sonatype. With this you can use your Windows machine to write the CRaC code and deploy it to your Linux machine where it will then make use of CRaC.

Can I use CRaC with my Java desktop application?

Graphical WS/Swing/Java FX applications are not yet supported with CRaC. Support for graphics is coming in the next releases.

What is the main use case for CRaC?

The principal use case is to reduce the startup and warmup times of the Java applications that have to be restarted frequently or that experience long startup and warmup times.

Description text

BLOG

Introducing the OpenJDK “Coordinated Restore at Checkpoint” Project

VIDEO

Java on CRaC: Superfast JVM Application Startup

BLOG

Micronaut 3.8.0: Build Scalable Applications with the Updated CRaC Feature

BLOG

How to Run a Java Application with CRaC in a Docker Container

Explore the benefits of CRaC technology.