8268388: Update large pages information in Java manpage

Reviewed-by: tschatzl, lkorinth, stuefe
This commit is contained in:
Stefan Johansson 2021-06-10 05:32:56 +00:00
parent 2623b0bf39
commit ece3ae3cc4

View File

@ -1403,22 +1403,23 @@ comma.
.RE
.TP
.B \f[CB]\-XX:LargePageSizeInBytes=\f[R]\f[I]size\f[R]
Sets the maximum size (in bytes) for large pages used for the Java heap.
The \f[I]size\f[R] argument must be a power of 2 (2, 4, 8, 16, and so
on).
Sets the maximum large page size (in bytes) used by the JVM.
The \f[I]size\f[R] argument must be a valid page size supported by the
environment to have any effect.
Append the letter \f[CB]k\f[R] or \f[CB]K\f[R] to indicate kilobytes,
\f[CB]m\f[R] or \f[CB]M\f[R] to indicate megabytes, or \f[CB]g\f[R] or
\f[CB]G\f[R] to indicate gigabytes.
By default, the size is set to 0, meaning that the JVM chooses the size
for large pages automatically.
By default, the size is set to 0, meaning that the JVM will use the
default large page size for the environment as the maximum size for
large pages.
See \f[B]Large Pages\f[R].
.RS
.PP
The following example describes how to set the large page size to 4
megabytes (MB):
The following example describes how to set the large page size to 1
gigabyte (GB):
.RS
.PP
\f[CB]\-XX:LargePageSizeInBytes=4m\f[R]
\f[CB]\-XX:LargePageSizeInBytes=1g\f[R]
.RE
.RE
.TP
@ -5120,9 +5121,8 @@ larger memory range.
This results in less pressure on a TLB, and memory\-intensive
applications may have better performance.
.PP
However, large pages page memory can negatively affect system
performance.
For example, when a large mount of memory is pinned by an application,
However, using large pages can negatively affect system performance.
For example, when a large amount of memory is pinned by an application,
it may create a shortage of regular memory and cause excessive paging in
other applications and slow down the entire system.
Also, a system that has been up for a long time could produce excessive
@ -5133,74 +5133,84 @@ When this happens, either the OS or JVM reverts to using regular pages.
Linux and Windows support large pages.
.SS Large Pages Support for Linux
.PP
The 2.6 kernel supports large pages.
Some vendors have backported the code to their 2.4\-based releases.
To check if your system can support large page memory, try the
following:
Linux supports large pages since version 2.6.
To check if your environment supports large pages, try the following:
.IP
.nf
\f[CB]
#\ cat\ /proc/meminfo\ |\ grep\ Huge
HugePages_Total:\ 0
HugePages_Free:\ 0
\&...
Hugepagesize:\ 2048\ kB
\f[R]
.fi
.PP
If the output shows the three "Huge" variables, then your system can
support large page memory but it needs to be configured.
If the command prints nothing, then your system doesn\[aq]t support
large pages.
To configure the system to use large page memory, login as
\f[CB]root\f[R], and then follow these steps:
.IP "1." 3
If you\[aq]re using the option \f[CB]\-XX:+UseSHM\f[R] (instead of
\f[CB]\-XX:+UseHugeTLBFS\f[R]), then increase the \f[CB]SHMMAX\f[R] value.
It must be larger than the Java heap size.
On a system with 4 GB of physical RAM (or less), the following makes all
the memory sharable:
.RS 4
If the output contains items prefixed with "Huge", then your system
supports large pages.
The values may vary depending on environment.
The \f[CB]Hugepagesize\f[R] field shows the default large page size in
your environment, and the other fields show details for large pages of
this size.
Newer kernels have support for multiple large page sizes.
To list the supported page sizes, run this:
.IP
.nf
\f[CB]
#\ ls\ /sys/kernel/mm/hugepages/
hugepages\-1048576kB\ \ hugepages\-2048kB
\f[R]
.fi
.PP
The above environment supports 2 MB and 1 GB large pages, but they need
to be configured so that the JVM can use them.
When using large pages and not enabling transparent huge pages (option
\f[CB]\-XX:+UseTransparentHugePages\f[R]), the number of large pages must
be pre\-allocated.
For example, to enable 8 GB of memory to be backed by 2 MB large pages,
login as \f[CB]root\f[R] and run:
.RS
.PP
\f[CB]#\ echo\ 4294967295\ >\ /proc/sys/kernel/shmmax\f[R]
\f[CB]#\ echo\ 4096\ >\ /sys/kernel/mm/hugepages/hugepages\-2048kB/nr_hugepages\f[R]
.RE
.RE
.IP "2." 3
If you\[aq]re using the option \f[CB]\-XX:+UseSHM\f[R] or
\f[CB]\-XX:+UseHugeTLBFS\f[R], then specify the number of large pages.
In the following example, 3 GB of a 4 GB system are reserved for large
pages (assuming a large page size of 2048kB, then 3 GB = 3 * 1024 MB =
3072 MB = 3072 * 1024 kB = 3145728 kB and 3145728 kB / 2048 kB = 1536):
.RS 4
.PP
It is always recommended to check the value of \f[CB]nr_hugepages\f[R]
after the request to make sure the kernel was able to allocate the
requested number of large pages.
.PP
When using the option \f[CB]\-XX:+UseSHM\f[R] to enable large pages you
also need to make sure the \f[CB]SHMMAX\f[R] parameter is configured to
allow large enough shared memory segments to be allocated.
To allow a maximum shared segment of 8 GB, login as \f[CB]root\f[R] and
run:
.RS
.PP
\f[CB]#\ echo\ 1536\ >\ /proc/sys/vm/nr_hugepages\f[R]
\f[CB]#\ echo\ 8589934592\ >\ /proc/sys/kernel/shmmax\f[R]
.RE
.PP
In some environments this is not needed since the default value is large
enough, but it is important to make sure the value is large enough to
fit the amount of memory intended to be backed by large pages.
.RS
.PP
\f[B]Note:\f[R] The values contained in \f[CB]/proc\f[R] resets after you
reboot your system, so may want to set them in an initialization script
(for example, \f[CB]rc.local\f[R] or \f[CB]sysctl.conf\f[R]).
\f[B]Note:\f[R] The values contained in \f[CB]/proc\f[R] and \f[CB]/sys\f[R]
reset after you reboot your system, so may want to set them in an
initialization script (for example, \f[CB]rc.local\f[R] or
\f[CB]sysctl.conf\f[R]).
.RE
.RE
.IP \[bu] 2
If you configure (or resize) the OS kernel parameters
\f[CB]/proc/sys/kernel/shmmax\f[R] or \f[CB]/proc/sys/vm/nr_hugepages\f[R],
Java processes may allocate large pages for areas in addition to the
Java heap.
These steps can allocate large pages for the following areas:
.RS 2
.IP \[bu] 2
Java heap
.PP
If you configure the OS kernel parameters to enable use of large pages,
the Java processes may allocate large pages for the Java heap as well as
other internal areas, for example:
.IP \[bu] 2
Code cache
.IP \[bu] 2
The marking bitmap data structure for the parallel GC
Marking bitmaps
.PP
Consequently, if you configure the \f[CB]nr_hugepages\f[R] parameter to
the size of the Java heap, then the JVM can fail in allocating the code
cache areas on large pages because these areas are quite large in size.
.RE
the size of the Java heap, then the JVM can still fail to allocate the
heap using large pages because other areas such as the code cache might
already have used some of the configured large pages.
.SS Large Pages Support for Windows
.PP
To use large pages support on Windows, the administrator must first