首先介绍下HugePages
HugePages是集成到Linux内核2.6中的功能。启用HugePages使操作系统能够支持大于默认值(通常为4KB)的内存页面。使用大页可以减少访问页表条目所需的系统资源量来提高系统性能。HugePages可用于32位和64位的系统配置。根据内核版本和硬件架构,大页大小从2MB到256MB不等。对于Oracle数据库,使用HugePages可减少页面状态的操作系统维护,并增加页表缓冲(TBL)的命中率
没有HugePages,操作系统将每个4KB的内存保存为一个页面,当它被分配给SGA时,该页面的生命周期(dirty,free,mapped to process等)根据系统内核保持最新的状态。
使用HugePages,操作系统页表(虚拟内存到物理内存映射)较小,因为每个页表条目都指向从2MB到256MB的页面。并且内核较少的页面,其生命周期一定会被监视。
注意2MB大小的HugePages可用于Linux x86-64,Linux x86和IBM:Linux on System z.
以下是使用HugePages的优点:
·通过增加TLB命中来提高性能。
·页面被锁定在内存中,不会被交换出来,保证像SGA这样的共享内存保留在RAM中。
·连续的页面是预先分配的,不能用于其他任何东西,而只能用于System V共享内存(例如:SGA)
·由于更大的页面大小,对于虚拟内存的这部分的内核而言,更少的记录工作
在Linux上配置HugePages
1.编辑/etc/security/limits.conf文件中的 memlock设定,memlock是以KB为单位,并且比内存稍微小一点,例如:如果你的内存是64GB,添加以下条目来增加最大的锁定内存限制
*soft memlock 60397977
*hard memlock 60397977
你还可以设置比SGA更高的memlock值
2.登录oracle用户,运行 ulimit -l 命令确认memlock设定完成:
ulimit -l
3.运行下面的命令来显示Hugepagesize变量的值
grep Hugepagesize /proc/meminfo
4.完成一下步骤,创建一个脚本,该脚本为当前共享内存端计算之后推荐的hugepages值
下面的例子需要根据自己的环境进行更改
a.创建一个名称为 hugepages_setting.sh
b.添加下面内容到文件中
#!/bin/bash
#
# hugepages_settings.sh
#
# Linux bash script to compute values for the
# recommended HugePages/HugeTLB configuration
#
# Note: This script does calculation for all shared memory
# segments available when the script is run, no matter it
# is an Oracle RDBMS shared memory segment or not.
# Check for the kernel version
KERN=`uname -r | awk -F. '{ printf("%d.%d\n",$1,$2); }'`
# Find out the HugePage size
HPG_SZ=`grep Hugepagesize /proc/meminfo | awk {
'print $2'}`
# Start from 1 pages to be on the safe side and guarantee 1 free HugePage
NUM_PG=1
# Cumulative number of pages required to handle the running shared memory segments
for SEG_BYTES in `ipcs -m | awk {
'print $5'} | grep "[0-9][0-9]*"`
do
MIN_PG=`echo "$SEG_BYTES/($HPG_SZ*1024)" | bc -q`
if [ $MIN_PG -gt