Linux Hugepage ,AMM及 USE_LARGE_PAGES - 1

Linux 6.1 


1.  Hugepage基本概念 

    系统进程是通过虚拟地址访问内存,但是CPU必须把它转换成物理内存地址才能真正访问内存。
为了提高这个转换效率,CPU会缓存最近的“虚拟内存地址和物理内存地址”的映射关系,并保存在
一个由CPU维护的映射表(page table)中。

    page table(页表)是操作系统上的虚拟内存系统的数据结构模型,用于存储虚拟地址与物理地
址的对应关系。当我们访问内存时,首先访问"page table",然后Linux再通过"page table"的mapping
来访问真实物理内存(RAM或SWAP).

    在32位系统下,一个进程访问1GB的内存,会产生1M的页表,如果是在64位系统,将会增大到2M。
很容易推算,如果一个SGA设置为60G,有1500个ORACLE用户进程,64位LINUX的系统上,最大的页表
占用内存为:60*2*1500/1024=175G 。


    为了尽量提高内存的访问速度,需要在映射表中保存尽量多的映射关系。而在Redhat Linux中,
内存都是以页(Page)的形式划分的,默认情况下每页是4K Bytes,这就意味着如果物理内存很大,比
如64G ,则映射表的条目将会非常多,这将会影响CPU的检索效率(CPU需要转化虚拟地址为物理地址)。
而且根据上面的推算,页表会占用比物理内存还多的内存大小。

   因内存大小是固定的,为了减少映射表的条目,可采取的办法只有增加页的尺寸。这种增大的内
存页尺寸在Linux 2.1中,称为Big page;在AS 3/4或后续版本中,称为Hugepage。如果系统有大量
的物理内存(大于8G),则无论32位的操作系统还是64位的,都应该使用Hugepage。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/35489/viewspace-1171322/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/35489/viewspace-1171322/

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值