http://kenwu.me/tune-large-page-for-jvm-optimization
本文将从内存分页的原理,如何调整分页大小两节内容,向你阐述LargePage对JVM的性能有何提升作用,并在文末点明了大内分页的副作用。OK,让我们开始吧!
内存分页大小对性能的提升原理
首先,我们需要回顾一小部分计算机组成原理,这对理解大内存分页至于JVM性能的提升是有好处的。
什么是内存分页?
我们知道,CPU是通过寻址来访问内存的。32位CPU的寻址宽度是 0~0xFFFFFFFF ,计算后得到的大小是4G,也就是说可支持的物理内存最大是4G。
但在实践过程中,碰到了这样的问题,程序使用4G内存,而可用物理内存小于4G,导致程序不得不降低内存占用。
为了解决此类问题,现代CPU引入了 MMU
(Memory Management Unit 内存管理单元)。
MMU 中的核心思想是用虚拟地址替代物理地址,即CPU寻址时使用虚址,由 MMU 负责将虚址映射为物理地址。
这种设计解决了物理内存小于4G对程序的限制,对程序来说,自己就像在使用4G内存一样。
内存分页(Paging)是在使用MMU的基础上,提出的一种有效内存管理机制。它将虚拟地址和物理地址按固定大小(4K)切割成页(page)和页帧(page frame),并且保证页与页帧的大小相同。
分页的好处是,提高访问内存的效率,支持非连续性内存分配,在程序内存不够用时,可以将不常用的物理内存页转移到其他存储设备上,比如磁盘,但必须以页为单位传输,这就是大家耳熟能详的虚拟内存。
在上文中提到,虚拟地址与物理地址要映射。这个映射的关系, 目前是被 MMU 存储在物理内存上一个被称之为页表(page table)的地方。
如下图:
从这张图中,可以清晰地看到CPU与页表,物理内存之间的交互关系。
进一步优化,引入TLB(Translation lookaside buffer,页表寄存器缓冲)
由上一节可知,页表是存储在内存中的。我们知道CPU通过总线访问内存,是慢于直接访问寄存器的。
为了进一步优化性能,现代CPU架构引入了TLB
,用来缓存一部分经常访问的页表内容。
如下图:
对比 9.6 那张图,在中间加入了TLB。
为什么要支持大内存分页?
TLB是有限的,这点毫无疑问。当超出TLB的存储极限时,就会发生 TLB miss,于是OS就会命令CPU去访问内存上的页表。如果频繁的出现TLB miss,程序的性能会下降地很快。
为了让TLB可以存储更多的页地址映射关系,我们的做法是调大内存分页大小。
如果一个页4M,对比一个页4K,前者可以让TLB多存储1000个页地址映射关系,性能的提升是比较可观的。
调整OS和JVM内存分页
在Linux和windows下要启用大内存页,有一些限制和设置步骤。
Linux:
限制:需要2.6内核以上或2.4内核已打大内存页补丁。
确认是否支持,请在终端敲如下命令:
# cat /proc/meminfo | grep Huge
HugePages_Total: 0
HugePages_Free: 0
Hugepagesize: 2048 kB
如果有HugePage字样的输出内容,说明你的OS是支持大内存分页的。Hugepagesize就是默认的大内存页size。
接下来,为了让JVM可以调整大内存页size,需要设置下OS 共享内存段最大值 和 大内存页数量。
共享内存段最大值
建议这个值大于Java Heap size,这个例子里设置了4G内存。
# echo 4294967295 > /proc/sys/kernel/shmmax
大内存页数量
# echo 154 > /proc/sys/vm/nr_hugepages
这个值一般是 Java进程占用最大内存/单个页的大小 ,比如java设置 1.5G,单个页 10M,那么数量为 1536/10 = 154。
注意:因为proc是内存FS,为了不让你的设置在重启后被冲掉,建议写个脚本放到 init 阶段(rc.local)。
Windows:
限制:仅支持 windows server 2003 以上server版本
操作步骤:
- Control Panel -> Administrative Tools -> Local Security Policy
- Local Policies -> User Rights Assignment
- 双击 “Lock pages in memory”, 添加用户和组
- 重启电脑
注意: 需要管理员操作。
单个页大小调整
JVM启用时加参数 -XX:LargePageSizeInBytes=10m
如果JDK是在1.5 update5以前的,还需要加 -XX:+UseLargePages,作用是启用大内存页支持。
大内存分页的副作用
因为每页size变大了,导致JVM在计算Heap内部分区(perm, new, old)内存占用比例时,会出现超出正常值的划分。最坏情况下是,某个区会多占用一个页的大小。不过后续jvm版本也在调整这个策略。
一般情况,不建议将页size调得太大,4-64M,是可以接受的(默认是4M),风险较小。为了合理设置这个值,你应该做对你的系统做一下benchmark。
网上我见过调得最猛的是,256M,从benchmark报表上看,不是太坏。如果你是64位的大内存机器,不妨尝试一下。
另外,网上很多GC调优的文章内容中都有提到 LargePageSizeInBytes,但未提任何OS限制。在OS不支持的情况下,这个参数,将仅仅是个摆设。
分享到:
相关推荐
JVM内存模型深度剖析与优化 JVM内存模型是Java虚拟机的核心组件之一,它直接影响着Java应用程序的性能和可靠性。本文将深入剖析JVM内存模型的结构和工作机理,并讨论如何优化JVM参数以提高Java应用程序的性能。 一...
二是物理解决,增大物理内存,然后通过调整 JVM 的参数来调整内存的大小。 JVM 内存溢出类型有两种:java.lang.OutOfMemoryError: PermGen space 和 java.lang.OutOfMemoryError: Java heap space。PermGen space ...
"Jvm性能优化-JVM内存结构原理分析03" Jvm性能优化是Java虚拟机(JVM)中非常重要的一部分,它对Jvm的性能产生了很大的影响。本文将从Jvm内存结构的角度来分析Jvm性能优化的原理。 Jvm内存结构主要分为五部分:堆...
标题中提到了JVM原理、JVM调优、JVM内存模型和JAVA并发,这些都是Java虚拟机(JVM)相关的核心概念。JVM是运行Java字节码的虚拟计算机,为Java提供了一个跨平台的环境,确保Java程序可以在不同的操作系统上运行而...
5. **JVM配置调整**:JProfiler11还可以提供JVM参数建议,帮助开发者正确设置JVM初始堆大小、最大堆大小、内存池等关键参数,确保应用程序稳定运行。 在实际使用中,JProfiler11的详细报告和可视化界面使得问题定位...
### JVM内存空间分配详解 #### 一、JVM内存模型概览 ...综上所述,理解JVM内存分配机制对于Java开发者来说至关重要,这不仅有助于编写高效、稳定的代码,还能在遇到性能瓶颈时快速定位问题并进行优化。
### JVM内存配置优化 #### 一、理解JVM内存模型 在进行JVM内存配置优化之前,我们需要了解Java虚拟机(JVM)的内存结构。Java的逻辑内存模型大致分为几个部分: 1. **堆内存(Heap)**:主要用于存储对象实例、数组...
特别是在大数据处理场景下,合理设置JVM内存参数显得尤为重要。本文将深入探讨JVM内存管理的基础概念、内存设置方法及其调优策略,以帮助开发者避免常见的`java.lang.OutOfMemoryError`异常,提升应用性能。 #### ...
1. 内存参数调整:通过调整-Xms、-Xmx设置堆大小,-XX:NewRatio控制年轻代与老年代比例,-XX:SurvivorRatio设置Eden和Survivor区比例,优化内存分配。 2. 对象池技术:减少频繁创建和销毁对象带来的开销,例如...
堆内存优化可以通过调整JVM启动参数来实现,如-Xms -Xmx -XX:newSize -XX:MaxNewSize等。永久区内存优化可以通过调整PermSize参数来实现,而栈内存优化可以通过调整每个线程的栈内存容量来实现。 在实际应用中,...
在开发和优化Java应用程序时,理解JVM内存日志至关重要,因为它可以帮助我们诊断性能问题,例如内存泄漏或过度的垃圾收集。`jmap`是Java的一个命令行工具,用于获取堆内存的详细信息,包括堆dump,这对于分析JVM内存...
总的来说,《淘宝JVM优化实践》展示了阿里巴巴在应对大规模Java应用挑战时,如何通过定制化JVM实现性能优化和功能增强,为其他大型互联网公司提供了宝贵的参考经验。通过深入研究和实践,淘宝团队成功地提高了系统的...
通过动态地调整`-Xms`和`-Xmx`参数,可以在运行时根据实际需求优化内存分配,从而提高程序的性能和稳定性。此外,定期检查和分析`heapSize`、`heapMaxSize`和`heapFreeSize`等指标,可以帮助开发者及时发现潜在的...
JVM的优化可以从多个方面进行,包括但不限于垃圾回收(Garbage Collection, GC)优化、JVM参数调整、内存管理优化、线程池调整和性能监控等。 垃圾回收优化是JVM优化中的一个关键点。JVM通过不同的垃圾回收器来管理...
这包括内存管理、垃圾回收(GC)机制的调整、编译器的优化等多方面的调整。性能调优的目标是减少内存占用、缩短响应时间、提高处理事务的能力以及减少垃圾回收造成的停顿时间。这些目标之间可能存在冲突,通常需要根据...
JVM内存优化是指通过调整JVM的内存参数,减少垃圾回收的频率和时间,以提高JVM的性能。例如,调整JVM的最大堆大小、调整垃圾回收算法、使用较新版本的JDK等。 应用配置优化是指通过调整Tomcat服务器的配置,提高...
总之,JVM优化涉及到内存分配、垃圾收集器选择、垃圾回收策略以及各种性能优化参数的调整。这些配置需要根据实际应用的负载、内存需求以及性能指标进行精细化调整,以确保应用程序的高效稳定运行。
总之,JVM性能优化是一个涵盖广泛且深度丰富的主题,涉及内存管理、垃圾收集、线程并发、代码优化等多个层面。通过深入学习和实践,开发者可以更好地驾驭JVM,使Java应用运行得更加高效、稳定。这份PPT提供了一个...
### Tomcat JVM内存优化(Linux环境) 在Linux环境下运行Tomcat服务器时,经常会遇到与Java虚拟机(JVM)相关的内存溢出问题。这些问题通常表现为`java.lang.OutOfMemoryError`异常,具体又分为两类:`PermGen ...