JVM调优

简介: 在了解JVM调优之前,我们先了解下java的内存管理:http://blog.csdn.net/cymm_liu/article/details/7759696 基于Java的应用最大的问题莫过于出现Out Of Memory Error(内存溢出错误),通常出现OOME问题的应用都会有以下一些表现:l         Jvm crashl         性能奇差l         Jvm似乎在不断的进行垃圾回收收集,这通常致使程序停止运行甚至服务崩溃 而且一旦出现这种情况,一般都需要重新启动应用服务器。
在了解JVM调优之前,我们先了解下java的内存管理:http://blog.csdn.net/cymm_liu/article/details/7759696
基于Java的应用最大的问题莫过于出现Out Of Memory Error(内存溢出错误),通常出现OOME问题的应用都会有以下一些表现:
l         Jvm crash
l         性能奇差
l         Jvm似乎在不断的进行垃圾回收收集,这通常致使程序停止运行甚至服务崩溃
 
而且一旦出现这种情况,一般都需要重新启动应用服务器。
 
OutOfMemoryError
如果JVM里运行的程序, 它的heap space和perm gen都满了,这个时候程序还企图创建新的对象实例的话,jvm gc就会启动,试图释放足够的内存来创建这个对象。这个时候如果gc无法释放出足够的内存,它就会抛出OutOfMemoryError内存溢出错误。
OutOfMemoryError通常是java内存泄漏引起的。内存泄漏的原因是一个对象虽然不被使用了,但是依然还有对象引用它,因此jvm gc就不会释放它所占据的内存,堆中也就少了块可用的空间。
通常解决这类问题需要从以下两个方面着手:
l         分析内存数据
l         观察堆的增长方式
 
GC工作机制
SUN的jvm内存池被划分为以下几个部分:
Eden Space (heap)——内存最初从这个线程池分配给大部分对象。
 
Survivor Space (heap)——用于保存在eden space内存池中经过垃圾回收后没有被回收的对象。
 
Tenured Generation (heap)——用于保持已经在survivor space内存池中存在了一段时间的对象。
 
Permanent Generation (non-heap)——保存虚拟机自己的静态(reflective)数据,例如类(class)和方法(method)对象。Java虚拟机共享这些类数据。这个区域被分割为只读的和只写的。
 
Code Cache (non-heap)——HotSpot Java虚拟机包括一个用于编译和保存本地代码(native code)的内存,叫做“代码缓存区”(code cache)。
 
简单来讲,jvm的内存回收过程是这样的:
对象在Eden Space创建,当Eden Space满了的时候,gc就把所有在Eden Space中的对象扫描一次,把所有有效的对象复制到第一个Survivor Space,同时把无效的对象所占用的空间释放。当Eden Space再次变满了的时候,就启动移动程序把Eden Space中有效的对象复制到第二个Survivor Space,同时,也将第一个Survivor Space中的有效对象复制到第二个Survivor Space。如果填充到第二个Survivor Space中的有效对象被第一个Survivor Space或Eden Space中的对象引用,那么这些对象就是长期存在的,此时这些对象将被复制到Permanent Generation。
若垃圾收集器依据这种小幅度的调整收集不能腾出足够的空间,就会运行Full GC,此时jvm gc停止所有在堆中运行的线程并执行清除动作。
JVM Tuning 工具
下面是整理的一份JVM调优工具介绍,重点介绍几个关键的:
jps
http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jps.html
jps使用很简单,在console输入jps即可,它是用来查看JVM里面所有进程的具体状态, 包括进程ID,进程启动的路径等等。
 
jconsole
http://java.sun.com/j2se/1.5.0/docs/guide/management/jconsole.html
jconsole是基于Java Management Extensions (JMX)的实时图形化监测工具,它利用了内建到JVM里面的JMX指令来提供实时的性能和资源的监控,包括了Java程序的内存使用,Heap size, 线程的状态,类的分配状态和空间使用等等。
注意:JBoss 4.0.2及以下版本不支持jconsole,在国际站测试过程中遇到了这个问题,查了JBoss JIRA才知道4.0.2版本的JMX实现并不标准。。。
 
jstat
http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jstat.html
jstat利用了JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对Heap size和垃圾回收状况的监控等等。它包含了以下几个options,能够对gc情况进行详细的监控:
-class
-compiler
-gc
-gccapacity
-gccause
-gcnew
-gcnewcapacity
-gcold
-gcoldcapacity
-gcpermcapacity
-gcutil
-printcompilation
 
我们常用的命令如:
 
jstat -gcutil -t -h10 $jvmpid 1s > _jvmstat_$jvmpid.$now.log &
 
它表示监控jvm gc状态,每秒钟刷新一次。每10次显示一次表头。
这是一个非常实用的工具,对我们jvm的gc状态和监控非常有帮助。对于希望远程监控jvm状态的人,则jstatd比较有用了。
 
jstatd
http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jstatd.html
       jstatd是jstat的守护进程,它能够提供远程jstat功能。使用它的服务需要设置security policy,一种方式是修改${java.home}/jre/lib/security/java.policy文件,在最后加入:
 
grant codebase "file:${java.home}/../lib/tools.jar" {
        permission java.security.AllPermission;
};
 
又或者,定义jstatd.policy文件,加入上面的策略,然后用如下脚本启动jstatd:
jstatd -J-Djava.security.policy=jstatd.policy
 
远程的监控命令:
jstat pid@hostip interval
如:
jstat 1234@127.0.0.1 1000
 
此时会监控127.0.0.1机器上进程id为1234的jvm gc情况,间隔1秒。
 
还有几个:
jstack
http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jstack.html
jstack工具可以用来获得java程序崩溃生成的core文件的java stack和native stack的信息,从而可以轻松地知道java程序是如何崩溃和在程序何处发生问题。另外,jstack工具还可以附属到正在运行的java程序中,看到当时运行的java程序的java stack和native stack的信息,如果现在运行的java程序呈现挂起的情况,jstack是非常有用的。
目前只有在Solaris和Linux的JDK版本里面才有。
 
jinfo
http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jinfo.html
jinfo可以从core文件里面知道崩溃的Java应用程序的配置信息。目前只有在Solaris和Linux的JDK版本里面才有。
 
jmap
http://java.sun.com/j2se/1.5.0/docs/tooldocs/share/jmap.html
jmap可以从core文件或进程中获得内存的具体匹配情况,包括Heap size, Perm size等等。目前只有在Solaris和Linux的JDK版本里面才有。
 
JVM调优参数
       JVM提供了很多调优参数,在此次调优过程中,我们发现采用以下几个jvm参数会使jvm变得非常稳定,这也是sun官方提供的生产环境调优参数,在sun的很多产品调优脚本中都可以看到这几个参数设置。
标准的JVM GC回收器不会回收Permanent Generation,但JVM提供了并发GC回收器来实现,首先我们要指定回收机制:
 
-XX:+UseConcMarkSweepGC
 
该参数适用于多核并存在缓存机制的应用中。它生成的gc回收曲线变化相比较并行GC而言更加平滑稳定。详细的参数说明可以参考sun的官方文档。
上面的参数是第一步,下一个参数告诉GC回收器能够操作Permanent Generation:
 
-XX:+CMSPermGenSweepingEnabled
 
而GC回收器是不会操作Classes的,这时候我们可以指定以下参数可以使得jvm能够unload class:
XX:+CMSClassUnloadingEnabled
相关文章
|
3月前
|
存储 监控 算法
jvm-性能调优(二)
jvm-性能调优(二)
|
15天前
|
监控 架构师 Java
Java虚拟机调优的艺术:从入门到精通####
本文作为一篇深入浅出的技术指南,旨在为Java开发者揭示JVM调优的神秘面纱,通过剖析其背后的原理、分享实战经验与最佳实践,引领读者踏上从调优新手到高手的进阶之路。不同于传统的摘要概述,本文将以一场虚拟的对话形式,模拟一位经验丰富的架构师向初学者传授JVM调优的心法,激发学习兴趣,同时概括性地介绍文章将探讨的核心议题——性能监控、垃圾回收优化、内存管理及常见问题解决策略。 ####
|
5月前
|
Arthas 监控 Java
(十一)JVM成神路之性能调优篇:GC调优、Arthas工具详解及各场景下线上最佳配置推荐
“在当前的互联网开发模式下,系统访问量日涨、并发暴增、线上瓶颈等各种性能问题纷涌而至,性能优化成为了现时代开发过程中炙手可热的名词,无论是在开发、面试过程中,性能优化都是一个常谈常新的话题”。
509 3
|
22天前
|
监控 Java 编译器
Java虚拟机调优指南####
本文深入探讨了Java虚拟机(JVM)调优的精髓,从内存管理、垃圾回收到性能监控等多个维度出发,为开发者提供了一系列实用的调优策略。通过优化配置与参数调整,旨在帮助读者提升Java应用的运行效率和稳定性,确保其在高并发、大数据量场景下依然能够保持高效运作。 ####
27 1
|
24天前
|
存储 算法 Java
JVM进阶调优系列(10)敢向stop the world喊卡的G1垃圾回收器 | 有必要讲透
本文详细介绍了G1垃圾回收器的背景、核心原理及其回收过程。G1,即Garbage First,旨在通过将堆内存划分为多个Region来实现低延时的垃圾回收,每个Region可以根据其垃圾回收的价值被优先回收。文章还探讨了G1的Young GC、Mixed GC以及Full GC的具体流程,并列出了G1回收器的核心参数配置,帮助读者更好地理解和优化G1的使用。
|
26天前
|
监控 Java 测试技术
Elasticsearch集群JVM调优垃圾回收器的选择
Elasticsearch集群JVM调优垃圾回收器的选择
46 1
|
1月前
|
Arthas 监控 Java
JVM进阶调优系列(9)大厂面试官:内存溢出几种?能否现场演示一下?| 面试就那点事
本文介绍了JVM内存溢出(OOM)的四种类型:堆内存、栈内存、元数据区和直接内存溢出。每种类型通过示例代码演示了如何触发OOM,并分析了其原因。文章还提供了如何使用JVM命令工具(如jmap、jhat、GCeasy、Arthas等)分析和定位内存溢出问题的方法。最后,强调了合理设置JVM参数和及时回收内存的重要性。
|
1月前
|
监控 Java 编译器
Java虚拟机调优实战指南####
本文深入探讨了Java虚拟机(JVM)的调优策略,旨在帮助开发者和系统管理员通过具体、实用的技巧提升Java应用的性能与稳定性。不同于传统摘要的概括性描述,本文摘要将直接列出五大核心调优要点,为读者提供快速预览: 1. **初始堆内存设置**:合理配置-Xms和-Xmx参数,避免频繁的内存分配与回收。 2. **垃圾收集器选择**:根据应用特性选择合适的GC策略,如G1 GC、ZGC等。 3. **线程优化**:调整线程栈大小及并发线程数,平衡资源利用率与响应速度。 4. **JIT编译器优化**:利用-XX:CompileThreshold等参数优化即时编译性能。 5. **监控与诊断工
|
1月前
|
存储 监控 Java
JVM进阶调优系列(8)如何手把手,逐行教她看懂GC日志?| IT男的专属浪漫
本文介绍了如何通过JVM参数打印GC日志,并通过示例代码展示了频繁YGC和FGC的场景。文章首先讲解了常见的GC日志参数,如`-XX:+PrintGCDetails`、`-XX:+PrintGCDateStamps`等,然后通过具体的JVM参数和代码示例,模拟了不同内存分配情况下的GC行为。最后,详细解析了GC日志的内容,帮助读者理解GC的执行过程和GC处理机制。
|
2月前
|
Arthas 监控 数据可视化
JVM进阶调优系列(7)JVM调优监控必备命令、工具集合|实用干货
本文介绍了JVM调优监控命令及其应用,包括JDK自带工具如jps、jinfo、jstat、jstack、jmap、jhat等,以及第三方工具如Arthas、GCeasy、MAT、GCViewer等。通过这些工具,可以有效监控和优化JVM性能,解决内存泄漏、线程死锁等问题,提高系统稳定性。文章还提供了详细的命令示例和应用场景,帮助读者更好地理解和使用这些工具。