源码先锋

源码先锋

Linux 中的“大内存页”(hugepage)是个什么?

admin 13 141

本文中我们会详细介绍大内存页(hugepage),让你能够回答:Linux中的“大内存页”是什么?在RHEL6、RHEL7、Ubuntu等Linux中,如何启用/禁用“大内存页”?如何查看“大内存页”的当前值?

首先让我们从“大内存页”的基础知识开始讲起。

Linux中的“大内存页”是个什么玩意?

“大内存页”有助于Linux系统进行虚拟内存管理。顾名思义,除了标准的4KB大小的页面外,它们还能帮助管理内存中的巨大的页面。使用“大内存页”,你最大可以定义1GB的页面大小。

在系统启动期间,你能用“大内存页”为应用程序预留一部分内存。这部分内存,即被“大内存页”占用的这些存储器永远不会被交换出内存。它会一直保留其中,除非你修改了配置。这会极大地提高像Oracle数据库这样的需要海量内存的应用程序的性能。

为什么使用“大内存页”?

在虚拟内存管理中,内核维护一个将虚拟内存地址映射到物理地址的表,对于每个页面操作,内核都需要加载相关的映射。如果你的内存页很小,那么你需要加载的页就会很多,导致内核会加载更多的映射表。而这会降低性能。

使用“大内存页”,意味着所需要的页变少了。从而大大减少由内核加载的映射表的数量。这提高了内核级别的性能最终有利于应用程序的性能。

简而言之,通过启用“大内存页”,系统具只需要处理较少的页面映射表,从而减少访问/维护它们的开销!

如何配置“大内存页”?

运行下面命令来查看当前“大内存页”的详细内容。

你的输出类似如上结果,只是数字会有一些出入。

这意味着,你系统需要124个每个2MB的“大内存页”!若你设置页面大小为4MB,则结果就变成了62。你明白了吧?

配置内核中的“大内存页”

本文最后一部分内容是配置上面提到的内核参数[1],然后重新加载。将下面内容添加到/etc/中,然后输入sysctl-p命令重新加载配置。

注意我们这里多加了两个额外的页,因为我们希望在实际需要的页面数量之外多一些额外的空闲页。

现在,内核已经配置好了,但是要让应用能够使用这些“大内存页”还需要提高内存的使用阀值。新的内存阀值应该为126个页x每个页2MB=252MB,也就是258048KB。

你需要编辑/etc/security/中的如下配置:

某些情况下,这些设置是在指定应用的文件中配置的,比如OracleDB就是在/etc/security//99-中配置的。

这就完成了!你可能还需要重启应用来让应用来使用这些新的巨大页。

如何禁用“大内存页”?

“大内存页”默认是开启的。使用下面命令来查看“大内存页”的当前状态。

输出中的[always]标志说明系统启用了“大内存页”。

若使用的是基于RedHat的系统,则应该要查看的文件路径为/sys/kernel/mm/redhat_transparent_hugepage/enabled。

若想禁用“大内存页”,则在/etc/中的kernel行后面加上transparent_hugepage=never,然后重启系统。

via:

作者:ShrikantLavhate[2]译者:lujun9972校对:wxy

本文由LCTT原创编译,Linux中国荣誉推出