linux内核功能关闭透明大页 功能,Red Hat Enterprise Linux 6 7关闭透明大页面及透明大页面基础概念...

决议

Note:

Transparent Huge Pages are

not available on the 32-bit version of RHEL 6.

For RHEL 7 see

How to disable transparent hugepages (THP) on Red Hat Enterprise Linux 7

For RHEL 8 see

How to disable transparent hugepages (THP) on Red Hat Enterprise Linux 8

Transparent Huge Pages (THP) are enabled by default in RHEL 6 for

all applications. The kernel attempts to allocate hugepages whenever possible and any Linux process will receive 2MB pages if the mmap region is 2MB naturally aligned. The main kernel address space itself is mapped with hugepages, reducing TLB pressure from kernel code. For general information on Hugepages, see:

What are Huge Pages and what are the advantages of using them?

The kernel will always attempt to satisfy a memory allocation using hugepages. If no hugepages are available (due to non availability of physically continuous memory for example) the kernel will fall back to the regular 4KB pages. THP are also swappable (unlike hugetlbfs). This is achieved by breaking the huge page to smaller 4KB pages, which are then swapped out normally.

But to use hugepages effectively, the kernel must find physically continuous areas of memory big enough to satisfy the request, and also properly aligned. For this, a

khugepaged kernel thread has been added. This thread will occasionally attempt to substitute smaller pages being used currently with a hugepage allocation, thus maximizing THP usage.

In userland, no modifications to the applications are necessary (hence transparent). But there are ways to optimize its use. For applications that want to use hugepages, use of

posix_memalign() can also help ensure that large allocations are aligned to huge page (2MB) boundaries.

Also, THP is only enabled for anonymous memory regions. There are plans to add support for tmpfs and page cache. THP tunables are found in the

/sys tree under

/sys/kernel/mm/redhat_transparent_hugepage.

The values for

/sys/kernel/mm/redhat_transparent_hugepage/enabled can be one of the following:

Raw

always   -  always use THP

never    -  disable THP

khugepaged will be automatically started when

transparent_hugepage/enabled is set to "always" or "madvise, and it'll be automatically shutdown if it's set to "never". The

redhat_transparent_hugepage/defrag parameter takes the same values and it controls whether the kernel should make aggressive use of memory compaction to make more hugepages available.

Check system-wide THP usage

Run the following command to check system-wide THP usage:

Raw

# grep AnonHugePages /proc/meminfo

AnonHugePages:    632832 kB

Note: Red Hat Enterprise Linux 6.2 or later publishes additional THP monitoring via

/proc/vmstat:

Raw

# egrep 'trans|thp' /proc/vmstat

nr_anon_transparent_hugepages 2018

thp_fault_alloc 7302

thp_fault_fallback 0

thp_collapse_alloc 401

thp_collapse_alloc_failed 0

thp_split 21

Check THP usage per process

Run the following command to monitor which processes are using THP:

Raw

# grep -e AnonHugePages  /proc/*/smaps | awk  '{ if($2>4) print $0} ' |  awk -F "/"  '{print $0; system("ps -fp " $3)} '

/proc/7519/smaps:AnonHugePages:    305152 kB

UID        PID  PPID  C STIME TTY          TIME CMD

qemu      7519     1  1 08:53 ?        00:00:48 /usr/bin/qemu-system-x86_64 -machine accel=kvm -name rhel7 -S -machine pc-i440fx-1.6,accel=kvm,usb=of

/proc/7610/smaps:AnonHugePages:    491520 kB

UID        PID  PPID  C STIME TTY          TIME CMD

qemu      7610     1  2 08:53 ?        00:01:30 /usr/bin/qemu-system-x86_64 -machine accel=kvm -name util6vm -S -machine pc-i440fx-1.6,accel=kvm,usb=

/proc/7788/smaps:AnonHugePages:    389120 kB

UID        PID  PPID  C STIME TTY          TIME CMD

qemu      7788     1  1 08:54 ?        00:00:55 /usr/bin/qemu-system-x86_64 -machine accel=kvm -name rhel64eus -S -machine pc-i440fx-1.6,accel=kvm,us

To disable THP at boot time

Append the following to the kernel command line in

grub.conf:

Raw

transparent_hugepage=never

Note: Certain ktune and/or tuned profiles specify to enable THP when they are applied. If the

transparent_hugepage=never parameter is set at boot time, but THP does not appear to be disabled after the system is fully booted. Refer to the following article:

Disabling transparent hugepages (THP) on Red Hat Enterprise Linux 6 is not taking effect

To disable THP at run time

Run the following commands to disable THP on-the-fly:

Raw

# echo never > /sys/kernel/mm/redhat_transparent_hugepage/enabled

# echo never > /sys/kernel/mm/redhat_transparent_hugepage/defrag

NOTE: Running the above commands will stop only creation and usage of the new THP. The THP which were created and used at the moment the above commands were run would not be disassembled into the regular memory pages. To get rid of THP completely the system should be rebooted with THP disabled at boot time.

NOTE: Some third party application install scripts check value of above files and complain even if THP is disabled at boot time using

transparent_hugepage=never, this is due to the fact when THP is disabled at boot time, the value of

/sys/kernel/mm/redhat_transparent_hugepage/defrag will not be changed, however this is expected and system will never go in THP defragmentation code path when it is disabled at boot and THP defrag need not to be disabled separately.

How to tell if Explicit HugePages is enabled or disabled

There can be two types of HugePages in the system: Explicit Huge Pages which are allocated explicitly by

vm.nr_hugepages sysctl parameter and Transparent Huge Pages which are allocated automatically by the kernel. See below on how to tell if Explicit HugePages is enabled or disabled.

Explicit HugePages DISABLED:

If the value of

HugePages_Total is "0" it means HugePages is

disabled on the system.

Raw

# grep -i HugePages_Total /proc/meminfo

HugePages_Total:       0

Similarly, if the value in

/proc/sys/vm/nr_hugepages file or

vm.nr_hugepages sysctl parameter is "0" it means HugePages is

disabled on the system:

Raw

# cat /proc/sys/vm/nr_hugepages

# sysctl vm.nr_hugepages

vm.nr_hugepages = 0

Explicit HugePages ENABLED:

If the value of

HugePages_Total is greater than "0", it means HugePages is

enabled on the system:

Raw

# grep -i HugePages_Total /proc/meminfo

HugePages_Total:       1024

Similarly if the value in

/proc/sys/vm/nr_hugepages file or

vm.nr_hugepages sysctl parameter is greater than "0", it means HugePages is

enabled on the system:

Raw

# cat /proc/sys/vm/nr_hugepages

1024

# sysctl vm.nr_hugepages

vm.nr_hugepages = 1024

Comments

RHEL 6 disables THP on systems with < 1G of ram. Refer to Red Hat

Bug 618444 - disable transparent hugepages by default on small systems for more information.

Disadvantages of using the explicit hugepages (libhugetlbfs): Using hugetlbfs requires significant work from both application developers and system administrators; explicit hugepages must be set aside at boot time, and applications must map them explicitly. The process is fiddly enough that use of hugetlbfs is restricted to those who really care and who have the time to mess with it. Hugetlbfs is often seen as a feature for large, proprietary database management systems and little else.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值