背景
Linux默认内存最小单位是页(page),其大小为4k,对于性能敏感型应用来说频繁切换页带来的时间开销累计就是性能损耗。而Linux恰好提供了大页(hugepage)来解决这个问题,默认大页的大小为2M,相当于512个最小页,大大减小了切页的频率从而减小了开销。
而大页的数量是需要在系统参数中进行配置的。
问题
如果预留的大页数量*2M大于总可用物理内存大小,就会导致Linux修改大页配置后启不起来了。
分析
假设可用内存为16G,则理论最大可配置大页数量为16*1024/2=8192,当然实际上配置这么多数量也是不可行的,因为操作系统自身也会占用一定的内存。在sudo vi /etc/sysctl.conf
中配置vm.nr_huge_pages=8192
之后,当场执行sudo sysctl -p
后发现ls
以及df -h .
还有cat /proc/meminfo
都无法呈现正常结果,说明预分配的大页总大小超过了可用内存总空间。此时如果执意重启就会发现启不起来了。
解决方案
修改大页配置时一定要提前理论计算所需总量以及可用总量,避免出现超出后再次启动机器失败的现象。同时可在修改后执行sudo sysctl -p
后,运行ls
以及df -h .
还有cat /proc/meminfo
等测试是否正常,如果不正常请立即修改配置的大页数量直到一些正常。
结论
大页内存可以一定程度上提高应用的性能表现,但是需要预先修改系统参数,此时需要非常谨慎避免预先分配的大页总大小大于可用内存大小,导致Linux修改大页配置后启不起来了。