本文转载自http://shift-alt-ctrl.iteye.com/blog/1842631
一.运行时数据区:
- 程序计数器:它是一块较小的内存空间,主要作用是当前线程所执行的字节码的行号指示器.由于java虚拟机的多线程是通过轮流切换并分配处理器执行时间的方式来实现的(协作式/抢占式?!),即任何时刻,任一CPU只会正在处理一个线程的指令;为了确保线程切换后能够正确恢复执行的位置,每个线程都有一个独立的程序计数器,每个计数器为线程私有.如果线程正在执行java方法,那么此计数器记录的是正在执行的字节码指令地址;如果执行的是Native方法,那么它(计数器)的值则为undefined.
- 虚拟机栈:线程私有,每个线程在执行java方法时都会被创建虚拟机栈,它用来存储方法执行期间的局部变量/操作数栈/动态连接表等.直到方法退出.局部变量表存放了编译期可知的各种基本类型(boolean,int,char...)以及对象引用类型(reference).如果线程请求的栈深度大于JVM所允许的深度,将会抛出statckOverflowError.
- 本地方法栈:对于native方法调用期间,jvm为线程创建的空间.在hotspot中,本地方法栈和虚拟机栈合二为一.
- 堆:JVM规范中阐述,所有的对象都将被存储在堆中;堆有可以根据对象的生命周期和收集策略,分为新生代和旧生代;其中新生代中为了便于GC和性能优化,再次分为Eden,from/to交换区三个小区.
- 方法区:通常称为持久带,此区为线程共享区域;用于存储VM加载的类信息/常量/静态变量等,它作为堆的逻辑部分,但在GC和空间使用上和堆有着很大的不同.方法区一般很少会被GC,但是方法区中的常量池以及类引用的卸载,仍然会被GC;当方法区空间不足时,仍会抛出OOM异常,如JSP预编译,cglib生成类.
- 运行时常量池:作为方法区的一部分,用于编译期生成的各种字面量和符号引用,它具有动态性,即在运行时仍然可以讲常量添加到常量池中,例如String.intern()方法.常量池会被GC.
- 直接内存(Directed Menory):通常发生在NIO中为了提升性能,将生命周期较长的buffer声明为直接内存,直接内存不会受到heap区域大小的限制(--Xms,--Xmx参数对其无效),直接内存的大小受到本机物理内存和OS-swap区域大小的限制,如果无法申请到直接内存,JVM也将抛出OOM异常. DirectByteBuffer = ByteBuffer.allocateDirect();
JVM采取了"直接内存指针"方式来访问对象,即本地变量表中维护的对象reference直接指向对象数据的内存地址,在此对象数据中包含了此对象类型的引用(Class),此方式对于操作对象更加快捷.
二.JVM常用调优/调试参数:
-Xms<size> |
例如:-Xms2G,设置Heap的初始大小 |
-Xmx<size> |
设置Heap的最大尺寸,建议为最大物理内存的1/3(建议此值不超过12G) |
-Xss<size> |
方法栈大小 |
-Xmn<size> |
新生代大小 |
-XX:NewSize=<value> -XX:MaxNewSize=<value> -XX:SurvivorRatio=<value> |
新生代设置.单位为byte SurvivorRatio = Eden/survivor;例如此值为3,则表示,Eden : from : to = 3:1:1;默认值为8 |
-XX:PermSize=<value> -XX:MaxPermSize=<value> |
方法区大小,max值默认为64M |
-XX:[+ | -]UseConcMarkSweepGC |
打开或关闭基于ParNew + CMS + SerialOld的收集器组合.(-XX:+UseParNewGC) |
-XX:[+ | -]UseParallelGC |
在server模式下的默认值(+),表示使用Parallel Scavenge + Serial Old收集器组合 |
-XX:[+ | -]UseParallelOldGC |
默认关闭,+表示打开/使用Parallel Scavenge + Parallel Old收集器组合 |
-XX:PretenureSizeThreshold=<value> |
直接晋升为旧生代的对象大小.大于此值的将会直接被分配到旧生代,单位byte |
-XX:MaxTenuringThreshold=<value> |
晋升到旧生代的对象年龄(已经或者即将被回收的次数);每个对象被minor GC一次,它的年龄+1,如果对象的年龄达到此值,将会进入旧生代. |
-XX:[+ | -]UseAdaptiveSizePolicy |
默认开启;是否动态调整java中堆中各个区域大小以及进入旧生代的年龄;此参数可以方便我们对参数调优,找到最终适合配置的参数. |
-XX:[+ | -]HandlePromotionFailure |
JDK1.6默认开启,是否支持内存分配失败担保策略;在发生Minor GC时,虚拟机会检测之前每次晋升到老年代的平均大小是否大于老年代的剩余空间大小,如果大于,则改为直接进行一次Full GC。如果小于,则查看HandlePromotionFailure设置是否允许担保失败;如果允许,那只会进行Minor GC;如果不允许,则也要改为进行一次Full GC。 |
-XX:ParallelGCThreads=<value> |
并行GC时所使用的线程个数.建议保持默认值(和CPU个数有换算关系). |
-XX:GCTimeRatio=<value> |
GC占JVM服务总时间比.默认为99,即允许1%的GC时间消耗.此参数只在Parallel Scavenge收集器下生效 |
-XX:CMSInitiatingOccupancyFraction=<value> |
设置CMS收集器在旧生代空间适用占比达到此值时,触发GC. |
-XX:[+ | -]UseCMSCompactAtFullCollection |
默认开启,表示在CMS收集器进行一次Full gc后是否进行一次内存碎片整理,[原因:CMS回收器会带来内存碎片] |
-XX:CMSFullGCSBeforeCompaction=<value> |
进行多少次FullGC之后,进行一次内存碎片整理.[原因:CMS回收器会带来内存碎片] |
参考样例:
JAVA_OPTS = "-verbose:gc
-Xms3G -Xmx=3G
-XX:MaxPermSize=256M
-XX:SurvivorRatio=3
-XX:MaxNewSize=1G
-XX:+UseConcMarkSweepGC
-XX:MaxTenuringThreshold=5
-XX:CMSInitiatingOccupancyFraction=70
-XX:+UseCMSCompactAtFullCollection
-XX:+PrintGCDetails
-XX:+PrintGCDateStamps
-Xloggc:../logs/server-gc.log.$(date +%Y%m%d%H%M)
-XX:+UseGCLogFileRotation
-XX:NumberOfGCLogFiles=1
-XX:GCLogFileSize=512M"
相关推荐
Java JVM(Java虚拟机)内存分配与调优是Java开发者必须掌握的重要技能,它涉及到程序的性能优化和稳定性。在Java应用中,JVM扮演着至关重要的角色,它负责解析字节码、管理内存以及执行线程等。本文将深入探讨JVM...
JAVA应用JVM原理及参数调优深入讲解视频.1 JAVA应用JVM原理及参数调优深入讲解视频.2 JAVA应用JVM原理及参数调优深入讲解视频.3 JAVA应用JVM原理及参数调优深入讲解视频.4 JAVA应用JVM原理及参数调优深入讲解视频.5 ...
标题中提到了JVM原理、JVM调优、JVM内存模型和JAVA并发,这些都是Java虚拟机(JVM)相关的核心概念。JVM是运行Java字节码的虚拟计算机,为Java提供了一个跨平台的环境,确保Java程序可以在不同的操作系统上运行而...
- **GC频率**:过高可能意味着内存分配不合理或存在内存泄漏。 - **暂停时间(Pause Time)**:长时间的GC暂停会影响用户体验,应尽可能降低。 - **吞吐量(Throughput)**:应用运行时间占总时间的比例,调优的目标...
jvm内存监控及调优方法,详细讲解jvm的原理以及常用调优手段
JVM内存管理是优化Java应用性能的关键环节,涉及到内存分配、垃圾回收以及内存溢出等问题。毕玄,一位在淘宝有着丰富经验的专家,通过他的演讲PPT,我们能深入理解JVM内存的实现、使用和调优。 ### 一、JVM内存实现...
此外,JVM参数调优是一个复杂的过程,涉及到许多因素,如应用的特性、工作负载模式、硬件配置等。例如,为了减少Full GC的频率,可能需要调整新生代和老年代的比例,或者选择适当的GC策略。在进行调优时,应结合理论...
JVM性能监控与调优实战课程,作为整篇课程的重中之重,非常值得同学们参考学习。课程前端讲解了JVM的性能监控和调优的概述,对调优的的方法和工具进行讲解学习,让同学们掌握方法,理解知识。课程的中间阶段我们进行...
3. 不稳定参数(不稳定参数):以“-XX”开头,这些是非标准化参数,主要用于JVM调优和Debug。它们可以开启或关闭某些特性,或者对某些特性设置具体的数值。例如,“-XX:+UseConcMarkSweepGC”用于启用CMS垃圾回收器...
在这个资源中,我们将详细讨论 JVM 内存参数的配置和调优,包括 JVM 的结构、内存管理、垃圾回收、堆和非堆内存、内存分配和限制等方面。 JVM 结构 JVM 的结构主要由六个部分组成:JVM API、JVM 内部组件、平台...
Java虚拟机(JVM)内存管理与调优是Java开发中的关键环节,它涉及到程序的性能、稳定性和资源效率。JVM内存分为多个区域,包括堆内存、方法区、程序计数器、虚拟机栈和本地方法栈。理解这些区域的工作原理以及如何...
理解GC工作原理有助于优化内存分配和减少垃圾收集的开销。 【JVM调优实践】 JVM调优包括选择合适的垃圾收集器、调整堆大小、设置新生代与老年代的比例、控制并发比等。例如,PS(Parallel Scavenge)和PO(Parallel...
《JVM工具、参数调优及调试技巧》 在Java开发中,理解并掌握JVM(Java虚拟机)的工作原理,以及如何进行工具使用、参数调优和问题调试,是提升程序性能的关键步骤。本文将深入探讨这些核心知识点,帮助开发者优化...
通过以上对JVM原理和参数调优的深入学习,开发者可以更好地理解Java应用程序的运行机制,优化系统性能,解决可能出现的内存溢出、性能瓶颈等问题。本课程详细讲解了这些内容,无论你是初学者还是经验丰富的开发者,...
### JVM内存参数调优详解 #### 一、概述 Java虚拟机(JVM)是执行Java字节码的软件环境,为了提高Java程序的性能和稳定性,合理调整JVM的内存参数至关重要。根据Java启动参数的不同分类,我们可以将其分为标准参数...
JVM面试资料。 JVM结构:类加载器,执行引擎,本地方法接口,本地内存结构; 四大垃圾回收算法:复制算法、标记-清除算法、标记-整理算法、分代收集算法 ...JVM调优:命令行指令,设置堆内存大小的参数
### JVM内存空间分配详解 #### 一、JVM内存模型概览 ...综上所述,理解JVM内存分配机制对于Java开发者来说至关重要,这不仅有助于编写高效、稳定的代码,还能在遇到性能瓶颈时快速定位问题并进行优化。
JVM参数调优部分未在提供的内容中显示,但一般来说,JVM参数调优会涉及到调整堆内存分配、堆外内存大小、垃圾回收器选择、新生代和老年代的比例,以及各种相关参数如-Xms、-Xmx、-Xmn、-XX:+UseG1GC等。这些调整能...
### JVM内存参数调优 在Java开发过程中,合理地配置JVM(Java虚拟机)的内存参数对于提高程序运行效率、避免内存溢出等问题至关重要。本文将深入探讨JVM内存参数调优的相关知识点,帮助开发者更好地理解并掌握如何...
【标题】"Tomcat JVM参数调优...总的来说,JVM参数调优是一个涉及内存分配、垃圾回收效率和系统资源平衡的复杂过程。适当的调优能确保Tomcat在处理大量并发请求时保持高效和稳定,同时避免内存问题导致的服务中断。