Java Runtime with CRaC Support
To use the CRAC functionality, you need a Java runtime that has support for CRaC integrated.
OpenJDK CRaC
LATEST OPENJDK CRAC RELEASEThe OpenJDK CRaC Project is developed in the GitHub repository github.com/openjdk/crac.
NOTE: The JDK archive should be extracted with sudo
.
$ sudo tar zxf <jdk>.tar.gz
When using CRaC, if you see an Operation not permitted
error, you may have to update your criu
permissions with:
sudo chown root:root $JAVA_HOME/lib/criu
sudo chmod u+s $JAVA_HOME/lib/criu
Azul Zulu Builds of OpenJDK
DOWNLOAD AZUL ZULU WITH CRACAzul integrated full CRaC functionality for Linux/x64 and Linux/Arm64, in version 17, 21, and 22 of Azul Zulu Builds of OpenJDK. This means, for now, you can run an application with CRaC on any system thanks to the crac.org dependency, but only on the specified OS systems the CRaC functionality in the JVM will work.
As of January 2024, downloads are also available for Windows and macOS of Zulu with CRaC support, but only for development purposes. With these runtimes you are able to simulate the CRaC functionality. When you request a checkpoint, it is created and immediately restored without dumping the checkpoint to disk. This enables you to develop and test the CRaC functionality on these platforms, so you can deploy your application with confidence on Linux.
AWS Lambda SnapStart
MORE INFO ABOUT AWS LAMBDA SNAPSTARTAWS Lambda SnapStart is a performance optimization developed by AWS that can significantly improve the startup time for applications. This feature delivers up to 10x faster function startup times for latency-sensitive Java applications at no extra cost, and with minimal or no code changes.