`

jVM 调优之-JVM 内存分析

 
阅读更多

转载:

    http://blog.csdn.net/wayne_sulong/article/details/7474793   

http://www.futurehandw.com/jvm  

http://hi.baidu.com/kingfly666666/item/e710a4371c60b0f1e7bb7a32

 

eclipse mat 下载:

http://www.eclipse.org/mat/downloads.php 

有两个版本,一个是 eclipse RPC 的版本, 建议下这个,

第两个,是下载 eclipse plugin 的版本。

  

主要有:jvisualVM  使用,

            Jmap

            jstat  等一些用法:

 具体见oracle 官方文档:

          http://docs.oracle.com/javase/1.5.0/docs/tooldocs/share/jstat.html

         http://docs.oracle.com/javase/1.5.0/docs/tooldocs/share/jstatd.html 

      http://docs.oracle.com/javase/1.5.0/docs/tooldocs/share/jps.html 

 http://www.iteye.com/topic/626801

 

java 内存分析:

      http://www.blogjava.net/rosen/archive/2010/06/13/323522.html 

http://www.blogjava.net/rosen/archive/2010/05/21/321575.html 

 http://www.ibm.com/developerworks/cn/opensource/os-cn-ecl-ma/index.html?ca=drs-

http://www.vogella.com/articles/EclipseMemoryAnalyser/article.html 

 

 

 jps  找到你的java执行类
> jstat -gcutil 10265(pid) 500 > gclog.txt &   ---- 表示要把显示的文件输入到一个文件中去
> tail -f gclog.txt

 

加入参数:-XX:+HeapDumpOnOutOfMemoryError

jvm:
d:\>jps  --- 查看java 进程的PID , 只能用来查看java 程序,不能查看系统中的程序的pid ,这个可以通过任务管理器来查看
d:\>jmap -dump:live,format=b,file=d:\heap.bin 4400<pid>
在eclipse 中VM arguments,或java_opts 中加入 -XX:+HeapDumpOnOutOfMemoryError 指在报出outofmemory时,会记录日志文件。
 通过jvm参数--XX:-HeapDumpOnOutOfMemoryError可以让JVM在出现内存溢出是Dump出当前的内存转储快照;

 

1,安装:

  • Update Site: http://download.eclipse.org/mat/1.2/update-site/
  •  

    用这个地址在eclipse 中去更新, 如果下载不了,就下个独立版本,

    http://www.eclipse.org/downloads/download.php?file=/mat/1.2.1/MemoryAnalyzer-1.2.1.201211051250.zip 

     

    符件中给出已下载的.zip 文件,

     

    安装:

        把它解压到 dropins \ 目录下, \  新建一个目录叫:Memory Analyzer ,把上面解压的放进去即可。 

     

       

     

    jvm参数调优给出以下几条经验。

    1:建议用64位操作系统,Linux下64位的jdk比32位jdk要慢一些,但是吃得内存更多,吞吐量更大。

    2:XMX和XMS设置一样大,MaxPermSize和MinPermSize设置一样大,这样可以减轻伸缩堆大小带来的压力。

    3:调试的时候设置一些打印参数,如-XX:+PrintClassHistogram -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintHeapAtGC -Xloggc:log/gc.log,这样可以从gc.log里看出一些端倪出来。

    4:系统停顿的时候可能是GC的问题也可能是程序的问题,多用jmap和jstack查看,或者killall -3 java,然后查看java控制台日志,能看出很多问题。有一次,网站突然很慢,jstack一看,原来是自己写的URLConnection连接太多没有释放,改一下程序就OK了。

    5:仔细了解自己的应用,如果用了缓存,那么年老代应该大一些,缓存的HashMap不应该无限制长,建议采用LRU算法的Map做缓存,LRUMap的最大长度也要根据实际情况设定。

    6:垃圾回收时promotion failed是个很头痛的问题,一般可能是两种原因产生,第一个原因是救助空间不够,救助空间里的对象还不应该被移动到年老代,但年轻代又有很多对象需要放入救助空间;第二个原因是年老代没有足够的空间接纳来自年轻代的对象;这两种情况都会转向Full GC,网站停顿时间较长。第一个原因我的最终解决办法是去掉救助空间,设置-XX:SurvivorRatio=65536 -XX:MaxTenuringThreshold=0即可,第二个原因我的解决办法是设置CMSInitiatingOccupancyFraction为某个值(假设70),这样年老代空间到70%时就开始执行CMS,年老代有足够的空间接纳来自年轻代的对象。

    7:不管怎样,永久代还是会逐渐变满,所以隔三差五重起java服务器是必要的,我每天都自动重起。

    8:采用并发回收时,年轻代小一点,年老代要大,因为年老大用的是并发回收,即使时间长点也不会影响其他程序继续运行,网站不会停顿。

    我的最终配置如下(系统8G内存),每天几百万pv一点问题都没有,网站没有停顿,2009年shedewang.com没有因为内存问题down过机。

    $JAVA_ARGS .= " -Dresin.home=$SERVER_ROOT -server -Xms6000M -Xmx6000M -Xmn500M -XX:PermSize=500M -XX:MaxPermSize=500M -XX:SurvivorRatio=65536 -XX:MaxTenuringThreshold=0 -Xnoclassgc -XX:+DisableExplicitGC -XX:+UseParNewGC -XX:+UseConcMarkSweepGC -XX:+UseCMSCompactAtFullCollection -XX:CMSFullGCsBeforeCompaction=0 -XX:+CMSClassUnloadingEnabled -XX:-CMSParallelRemarkEnabled -XX:CMSInitiatingOccupancyFraction=90 -XX:SoftRefLRUPolicyMSPerMB=0 -XX:+PrintClassHistogram -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintHeapAtGC -Xloggc:log/gc.log ";

    说明一下, -XX:SurvivorRatio=65536 -XX:MaxTenuringThreshold=0就是去掉了救助空间;
    -Xnoclassgc禁用类垃圾回收,性能会高一点;
    -XX:+DisableExplicitGC禁止System.gc(),免得程序员误调用gc方法影响性能;
    -XX:+UseParNewGC,对年轻代采用多线程并行回收,这样收得快;
    带CMS参数的都是和并发回收相关的,不明白的可以上网搜索;
    CMSInitiatingOccupancyFraction,这个参数设置有很大技巧,基本上满足(Xmx-Xmn)*(100-CMSInitiatingOccupancyFraction)/100>=Xmn就不会出现promotion failed。在我的应用中Xmx是6000,Xmn是500,那么Xmx-Xmn是5500兆,也就是年老代有5500兆,CMSInitiatingOccupancyFraction=90说明年老代到90%满的时候开始执行对年老代的并发垃圾回收(CMS),这时还剩10%的空间是5500*10%=550兆,所以即使Xmn(也就是年轻代共500兆)里所有对象都搬到年老代里,550兆的空间也足够了,所以只要满足上面的公式,就不会出现垃圾回收时的promotion failed;
    SoftRefLRUPolicyMSPerMB这个参数我认为可能有点用,官方解释是softly reachable objects will remain alive for some amount of time after the last time they were referenced. The default value is one second of lifetime per free megabyte in the heap,我觉得没必要等1秒;

    网上其他介绍JVM参数的也比较多,估计其中大部分是没有遇到promotion failed,或者访问量太小没有机会遇到,(Xmx-Xmn)*(100-CMSInitiatingOccupancyFraction)/100>=Xmn这个公式绝对是原创,真遇到promotion failed了,还得这么处理。

     

     

     

     64位的用上面的配置有6秒多停顿,但用下面的配置就没有问题,可能是救助空间的问题,下面的设置回收得很干净。
      $JAVA_ARGS .= " -Dresin.home=$SERVER_ROOT -server -Xmx2048M -Xms2048M -Xmn256M -XX:PermSize=512M -XX:MaxPermSize=512M -Xss256k -Xnoclassgc -XX:+DisableExplicitGC -XX:+UseConcMarkSweepGC -XX:+UseParNewGC -XX:+CMSParallelRemarkEnabled -XX:+UseCMSCompactAtFullCollection -XX:LargePageSizeInBytes=128M -XX:+UseFastAccessorMethods -XX:+UseCMSInitiatingOccupancyOnly -XX:CMSInitiatingOccupancyFraction=70 -XX:+PrintClassHistogram -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintHeapAtGC -Xloggc:log/gc.log ";

     

     

     Java参数-Xms和-Xmx的区别
       java内存堆栈不够用时我们会寻求java参数-Xms和-Xmx的帮助,网上也有许多前辈给出了例子,但很多人喜欢把-Xms和-Xmx的值设置成一样的,甚至我还见过有吧-Xms设的比-Xmx还要大(-Xms是最小值,-Xmx是最大值)。
        一开始我也不知道这两个值设成一样会有什么问题,但是我在作项目http://youmonitor.us/ 时发现,当我把-Xms和-Xmx设置成一样时,java会不断地吃内存。起先不知道怎么回事,经过测试后发现,原来java的垃圾回收器在内存使用达到-Xms值的时候才会开始回收,如果两个值一样,那就意味着,只有当java使用完所有内存时才会回收垃圾,这样一来内存当然不停的涨。希望我的教训对各位有所帮助。

     

     

     

     

     

     

     

     

     

     

     

    分享到:
    评论

    相关推荐

      JVM调优总结 -Xms -Xmx -Xmn -Xss

      JVM调优总结 -Xms -Xmx -Xmn -Xss JVM 调优是 Java virtual machine 的性能优化,通过调整 JVM 的参数来提高 Java 应用程序的性能。其中,-Xms、-Xmx、-Xmn、-Xss 是四个重要的参数,分别控制 JVM 的初始堆大小、...

      Jvm调优练习-jvm-tuning.zip

      JVM调优涉及到调整一系列参数,以优化应用程序的性能,包括内存分配、垃圾收集策略、线程管理以及编译器优化等。 【描述】"Jvm调优练习-jvm-tuning" 暗示了这个压缩包可能包含一系列实验或教程,帮助用户通过实际...

      JVM调优总结 Xms -Xmx -Xmn -Xss

      ### JVM调优总结:Xms、Xmx、Xmn、Xss 在Java虚拟机(JVM)的运行过程中,合理的参数配置对于提高程序性能至关重要。本文将对JVM调优中的几个关键参数进行深入解析,包括-Xms、-Xmx、-Xmn和-Xss等,帮助开发者更好...

      JVM调优测试-jvmDemo.zip

      1. **JVM内存模型**:JVM内存分为堆内存(Heap)、方法区(Method Area)、虚拟机栈(JVM Stack)、本地方法栈(Native Method Stack)和程序计数器(PC Register)。了解这些区域的功能和交互是调优的基础。 2. **...

      jvm调优学习-optimizeJVM.zip

      JVM调优是一项重要的技能,它能够帮助提升应用性能、减少内存消耗以及改善整体系统稳定性。"jvm调优学习-optimizeJVM.zip" 文件可能包含了一系列关于JVM调优的学习资料,特别是"optimizeJVM-develop"这个子文件可能...

      JVM 调优演示-JVM.zip

      JVM调优是一项重要的技能,它能够帮助我们优化应用程序的性能,减少内存消耗,提高响应速度,确保系统的稳定性和可扩展性。本资料"JVM 调优演示-JVM.zip"包含了一个名为"JVM-master"的项目,我们可以从以下几个方面...

      jvm 调优笔记-jvm.zip

      JVM调优是提高Java应用程序性能的关键步骤,涉及到多个方面,包括堆内存设置、垃圾收集器选择、类加载机制、线程管理等。以下是对这些关键知识点的详细阐述: 1. **堆内存配置** - **新生代与老年代**:JVM堆内存...

      用于复现 OOM bug,模拟JVM调优经历-JVMTest.zip

      "用于复现 OOM bug,模拟JVM调优经历-JVMTest.zip"文件提供了一个实战平台,让我们可以模拟JVM内存状况,学习如何识别和解决内存溢出问题。 首先,JVM的内存区域主要分为堆(Heap)、方法区(Method Area)、虚拟机...

      推荐一些JVM原理,JVM调优,JVM内存模型,JAVA并发 电子书1

      标题中提到了JVM原理、JVM调优、JVM内存模型和JAVA并发,这些都是Java虚拟机(JVM)相关的核心概念。JVM是运行Java字节码的虚拟计算机,为Java提供了一个跨平台的环境,确保Java程序可以在不同的操作系统上运行而...

      内容主要涉及分布式、并发、jvm调优相关-Poet.zip

      JVM调优包括内存管理(堆大小、新生代与老年代的比例、GC算法的选择)、线程配置(栈大小、线程池大小)、类加载优化(预加载、类去缓存)等。熟悉JMX(Java Management Extensions)工具,理解垃圾收集器的工作原理...

      lendengine应用JVM调优方案 - 面试用1

      《lendengine应用JVM调优实践与案例分析》 在现代互联网应用中,JVM调优是一项至关重要的任务,特别是在处理高并发、大数据量的业务场景中。以lendengine为例,其在架构设计中,为了提高日志处理效率,采用了中间件...

      JVM性能调优-JVM内存整理及GC回收

      《JVM性能调优-JVM内存整理及GC回收》是一份深入探讨Java虚拟机(JVM)优化的重要学习资料,特别适合对JAVA编程有经验的开发者。这份文档详细阐述了JVM性能调优的关键概念,包括JVM内存模型、垃圾回收(Garbage ...

      jvm调优测试仓库-jvm-monitor.zip

      JVM调优是优化Java应用程序性能的关键环节,而"jvm-monitor"则提供了一种工具集来帮助开发者监控和分析JVM的状态。本文将深入探讨JVM调优的概念、方法以及如何利用"jvm-monitor"进行有效的监控。 一、JVM调优基础 ...

      练习JVM调优-jvm_demo.zip

      JVM调优是一项核心技能,可以帮助我们优化应用程序的性能,减少内存消耗,提高响应速度,以及避免可能出现的垃圾收集问题。"练习JVM调优-jvm_demo.zip"是一个压缩包,包含了用于JVM调优实践的示例项目"jvm_demo-...

      JVM 参数调优-optimization-jvm.zip

      1. **JVM内存模型**:JVM内存主要分为堆内存(Heap)、方法区(Method Area)、虚拟机栈(JVM Stack)、本地方法栈(Native Method Stack)和程序计数器(Program Counter Register)。了解每个区域的作用和配置参数...

      jvm-full-gc调优-jvm-full-gc.zip

      1. **理解JVM内存结构**:Java内存主要分为堆内存(Heap)和非堆内存(Non-Heap),其中堆内存又分为新生代(Young Generation)、老年代(Tenured Generation或Old Generation)和持久代(Permanent Generation或...

      JVM的调优总结----------

      ### JVM调优总结 #### 1. JVM配置 在Java应用程序的运行过程中,JVM(Java虚拟机)扮演着至关重要的角色。为了确保应用程序能够高效稳定地运行,正确配置JVM参数至关重要。以下是一些常见的JVM配置参数及其含义: ...

      JVM调优总结1-12.docx

      JVM调优总结 JVM(Java Virtual Machine)是 Java 语言的运行环境,负责将 Java 字节码转换为机器码并执行。然而,随着 Java 应用程序的复杂度和规模的增加,JVM 的性能变得越来越重要。因此,JVM 调优是非常必要的...

      JVM性能调优-JVM内存整理及GC回收.pdf_java_jvm_

      《JVM性能调优——JVM内存整理及GC回收》是针对Java开发人员的重要主题,尤其是在大型企业级应用中,确保JVM(Java虚拟机)的高效运行是至关重要的。本资料深入探讨了如何通过调整JVM内存设置和优化垃圾回收机制来...

    Global site tag (gtag.js) - Google Analytics