Chapter 23. Configuring an operating system to optimize memory access
This section describes how to configure the operating system to optimize memory access across workloads, and the tools you can use to do so.
23.1. Tools for monitoring and diagnosing system memory issues
The following tools are available in Red Hat Enterprise Linux 8 for monitoring system performance and diagnosing performance problems related to system memory:
vmstattool, provided by the
procps-ngpackage, displays reports of a system’s processes, memory, paging, block I/O, traps, disks, and CPU activity. It provides an instantaneous report of the average of these events since the machine was last turned on, or since the previous report.
valgrindis a framework that provides instrumentation to user-space binaries. Install this tool, using the
yum install valgrindcommand. It includes a number of tools, that you can use to profile and analyze program performance, such as:
memcheckoption is the default
valgrindtool. It detects and reports on a number of memory errors that can be difficult to detect and diagnose, such as:
- Memory access that should not occur
- Undefined or uninitialized value use
- Incorrectly freed heap memory
- Pointer overlap
Memcheck can only report these errors, it cannot prevent them from occurring. However,
memchecklogs an error message immediately before the error occurs.
cachegrindoption simulates application interaction with a system’s cache hierarchy and branch predictor. It gathers statistics for the duration of application’s execution and outputs a summary to the console.
massifoption measures the heap space used by a specified application. It measures both useful space and any additional space allocated for bookkeeping and alignment purposes.
For more information, see the
For more information on the
valgrindframework, see the
23.2. Overview of a system’s memory
The Linux Kernel is designed to maximize the utilization of a system’s memory resources (RAM). Due to these design characteristics, and depending on the memory requirements of the workload, part of the system’s memory is in use within the kernel on behalf of the workload, while a small part of the memory is free. This free memory is reserved for special system allocations, and for other low or high priority system services. The rest of the system’s memory is dedicated to the workload itself, and divided into the following two categories:
Pages added in this category represent parts of files in permanent storage. These pages, from the page cache, can be mapped or unmapped in an application’s address spaces. You can use applications to map files into their address space using the
mmapsystem calls, or to operate on files via the buffered I/O read or write system calls.
Buffered I/O system calls, as well as applications that map pages directly, can re-utilize unmapped pages. As a result, these pages are stored in the cache by the kernel, especially when the system is not running any memory intensive tasks, to avoid re-issuing costly I/O operations over the same set of pages.
- Pages in this category are in use by a dynamically allocated process, or are not related to files in permanent storage. This set of pages back up the in-memory control structures of each task, such as the application stack and heap areas.
Figure 23.1. Memory usage patterns
23.3. Optimizing a system’s memory utilization
This section provides information about memory-related kernel parameters and how you can use them to improve a system’s memory utilization. The following are the memory-related kernel parameters available in Red Hat Enterprise Linux 8:
23.3.1. Virtual memory parameters
The virtual memory parameters are listed in the
/proc/sys/vm directory unless otherwise indicated.
The following are the available virtual memory parameters:
Is a percentage value. When this percentage of the total system memory is modified, the system begins writing the modifications to the disk with the
pdflushoperation. The default value is 20 percent.
- A percentage value. When this percentage of total system memory is modified, the system begins writing the modifications to the disk in the background. The default value is 10 percent.
Defines the conditions that determine whether a large memory request is accepted or denied.The default value is 0.
By default, the kernel performs heuristic memory overcommit handling by estimating the amount of memory available and failing requests that are too large. However, since memory is allocated using a heuristic rather than a precise algorithm, overloading memory is possible with this setting.
- When this parameter is set to 1, the kernel performs no memory overcommit handling. This increases the possibility of memory overload, but improves performance for memory-intensive tasks.
When this parameter is set to 2, the kernel denies requests for memory equal to or larger than the sum of the total available swap space and the percentage of physical RAM specified in the
overcommit_ratio. This reduces the risk of overcommitting memory, but is recommended only for systems with swap areas larger than their physical memory.
Specifies the percentage of physical RAM considered when
overcommit_memoryis set to 2. The default value is 50.
- Defines the maximum number of memory map areas that a process can use. The default value is 65530. Increase this value if your application needs more memory map areas.
Sets the size of the reserved free pages pool. It is also responsible for setting the
high_pagethresholds that govern the behavior of the Linux kernel’s page reclaim algorithms. It also specifies the minimum number of kilobytes to keep free across the system. This calculates a specific value for each low memory zone, each of which is assigned a number of reserved free pages in proportion to their size.
- Increasing the parameter value effectively reduces the application working set usable memory. Therefore, you might want to use it for only kernel-driven workloads, where driver buffers need to be allocated in atomic contexts.
Decreasing the parameter value might render the kernel unable to service system requests, if memory becomes heavily contended in the system.Warning
Extreme values can be detrimental to the system’s performance. Setting the
vm.min_free_kbytesto an extremely low value prevents the system from reclaiming memory effectively, which can result in system crashes and failure to service interrupts or other kernel services. However, setting
vm.min_free_kbytestoo high considerably increases system reclaim activity, causing allocation latency due to a false direct reclaim state. This might cause the system to enter an out-of-memory state immediately.
vm.min_free_kbytesparameter also sets a page reclaim watermark, called
min_pages. This watermark is used as a factor when determining the two other memory watermarks,
high_pages, that govern page reclaim algorithms.
In the event that a system runs out of memory, and the
panic_on_oomparameter is set to 0, the
oom_killerfunction kills processes, starting with the process that has the highest
oom_score, until the system recovers.
oom_adjparameter determines the
oom_scoreof a process. This parameter is set per process identifier. A value of -17 disables the
oom_killerfor that process. Other valid values range from -16 to 15.
Processes created by an adjusted process inherit the
oom_score of that process.
The swappiness value, ranging from 0 to 100, controls the degree to which the system favors reclaiming memory from the anonymous memory pool, or the page cache memory pool.
- Higher values favor file-mapped driven workloads while swapping out the less actively accessed processes’ anonymous mapped memory of RAM. This is useful for file-servers or streaming applications that depend on data, from files in the storage, to reside on memory to reduce I/O latency for the service requests.
Low values favor anonymous-mapped driven workloads while reclaiming the page cache (file mapped memory). This setting is useful for applications that do not depend heavily on the filesystem information, and heavily utilize dynamically allocated and private memory, such as mathematical and number crunching applications, and few hardware virtualization supervisors like QEMU.
The default value of the
vm.swappinessparameter is 30.Warning
0aggressively avoids swapping anonymous memory out to a disk, this increases the risk of processes being killed by the
oom_killerfunction when under memory or I/O intensive workloads.
For more information, see the
- For more information on how to set these parameters temporarily and persistently, see Section 23.3.4, “Setting memory-related kernel parameters”.
23.3.2. File system parameters
The file system parameters are listed in the
/proc/sys/fs directory. The following are the available file system parameters:
- Defines the maximum allowed number of events in all active asynchronous input/output contexts. The default value is 65536, and modifying this value does not pre-allocate or resize any kernel data structures.
Determines the maximum number of file handles for the entire system. The default value on Red Hat Enterprise Linux 8 is either 8192 or one tenth of the free memory pages available at the time the kernel starts, whichever is higher.
Raising this value can resolve errors caused by a lack of available file handles.
For more information, see the
23.3.3. Kernel parameters
The default values for the kernel parameters are located in the
/proc/sys/kernel/ directory. These values are calculated by the kernel at boot time depending on the available system resources.
The following are the available kernel parameters used to set up limits for the
shm* System V IPC (
sysvipc) system calls:
Defines the maximum allowed size in bytes of any single message in a message queue. This value must not exceed the size of the queue (
msgmnb). Use the
sysctl msgmaxcommand to determine the current
msgmaxvalue on your system.
Defines the maximum size in bytes of a single message queue. Use the
sysctl msgmnbcommand to determine the current
msgmnbvalue on your system.
Defines the maximum number of message queue identifiers, and therefore the maximum number of queues. Use the
sysctl msgmnicommand to determine the current
msgmnivalue on your system.
Defines the total amount of shared memory pages that can be used on the system at one time. For example, a page is 4096 bytes on the AMD64 and Intel 64 architecture. Use the
sysctl shmallcommand to determine the current
shmallvalue on your system.
Defines the maximum size in bytes of a single shared memory segment allowed by the kernel. Use the
sysctl shmmaxcommand to determine the current
shmmaxvalue on your system.
- Defines the system-wide maximum number of shared memory segments. The default value is 4096 on all systems.
For more information, see the