-XX:CheckpointGCThreads

(Linux® x86, Linux on POWER® (Little Endian), Linux on AArch64, and Linux on IBM Z® only)

At the VM startup, you can set the number of threads that the garbage collector uses for parallel operations (-Xgcthreads). At the time of taking the checkpoint, the -XX:CheckpointGCThreads option reduces the number of garbage collection (GC) threads that was set at startup.

Restrictions: This option takes effect only when -XX:+EnableCRIUSupport is enabled.

Syntax

    -XX:CheckpointGCThreads=<number>
Setting Value Default
<number> Greater than 0 and less than or equal to the number of GC threads at the VM startup 4

If the <number> is greater than the number of GC threads at startup, the VM ignores this option.

Explanation

When taking a checkpoint, the VM reduces the number of GC threads that was specified at the startup and makes it equal to the thread count specified in the -XX:CheckpointGCThreads option. Since restoring threads adds latency to the overall VM restore time, you can minimize the restore time by reducing the GC thread count. After restoring from the checkpoint, the VM increases the GC thread count. The VM checks the following settings to determine the new GC thread count at the time of restore:

If you have specified the GC thread count at restore in the -Xgcthreads option and the count is greater than the checkpoint GC threads, the VM increases the thread count to the GC thread count set at restore.

If you have not specified the GC thread count in the -Xgcthreads option or if the thread count is less than the checkpoint GC threads, then the VM determines the default thread count (as explained in the -Xgcthreads topic) at restore. If the default thread count is greater than the checkpoint thread count, then the VM increases the thread count to the default thread count.

If the default thread count is lesser than the checkpoint thread count, then the thread count at restore time is same as the checkpoint thread count.

See also