• 性能测试学习第十天-----性能案例分析之内存泄露


    一、查看Jvm运行状态的命令

      监控jvm的GC情况:  jstat -gcutil pid 1000 100
      查看jvm配置信息:
        jmap -heap pid:可以看到java进程的堆的配置信息,各区的空间大小和配置信息
      查看jvm中类和对象的占用情况:
        jmap -histo 5279 | head -20:查看jvm中各个类的实例数、占用内存数量以及类的全名
      堆文件dump:
        jmap -dump:format=b,file=m.hdump 17777:对堆内存进行dump,以文件的形式进行保存下来,可以用jvisualvm等工具对文件进行分析

    二、内存泄露有什么现象?
      1,tps出现大幅波动,并慢慢降低,甚至降为0,响应时间随之波动,慢慢升高
      2,通过jstat命令看到,Jvm中Old区不断增加,FullGC非常频繁,对应的FullGC消耗的时间也不断增加
      3,通过jconsole/jvisualvm可以看到,堆内存曲线不断上升,接近上限时,变成一条直线
      4,日志报错java.lang.OutOfMemoryError: Java heap space

    在案例练习前,先修改tomcat目录下conf/context.xml,将 <Manager pathname="" />这行的注释打开

    三、内存泄露怎么定位?

      1,通过jmap命令:jmap -histo pid | head -20,查看当前堆内存中实例数和占用内存最多的前20个对象
      2,通过jvisualvm,进行远程堆dump,然后把dump文件下载下来,用jvisualvm打开进行分析,可以看到更直观的jvm中对象的信息

    四、在什么样的场景下监控内存泄露问题?

      1,在试压阶段,或任意场景都可以考虑通过jvisualvm和jstat监控jvm的情况
      2,在稳定性场景中,一定要关注Jvm内存使用的情况,在长时间的压测下,最容易看出内存泄露的问题

    五、Jvm常见参数

      -Xms2048m:初始堆大小,建议<物理内存的1/4,默认值为物理内存的1/64
      -Xmx2048m:最大堆大小,建议与-Xms保持一致,默认值为物理内存的1/4
      -Xmn512m:新生代大小,建议不超过堆内存的1/2-Xss256k,线程堆栈大小,建议256k
      -XX:PermSize=256m:永久代初始值,默认值为物理内存的1/64
      -XX:MaxPermSize=256m:永久代最大值,默认值为物理内存的1/4
      -XX:SurvivorRatio=8:年轻带中Eden区和Survivor区的比例,默认为8:1,即Eden(8),FromSpace(1),ToSpace(1)
      -XX:MaxTenuringThreshold=15:晋升到老年代的对象年龄,每个对象坚持过一次MinorGC后对象年龄+1,默认值是15,年龄超过15进入到老年代,该参数在串行GC时有效-
      XX:PretenureSizeThreshold=3145728:单位字节,只对Serial和ParNew两款收集器有效,新生代采用Parallel Scavenge GC时无效,大于这个值的对象直接在老年代进行分配

      CMS相关参数
      -XX:+UseConcMarkSweepGC:默认关闭,ParNew+CMS+Serial Old,当CMS收集器出现
      ConcurrentModeFailure错误(Jvm预留空间不足以容纳程序使用),采用后备收集器Serial Old
      -XX:CMSInitiatingOccupancyFraction=80:CMS收集器在老年代空间被使用多少时触发FullGC,默认为92
      -XX:+UseCMSCompactAtFullCollection:CMS收集器在FullGC时开启内存碎片的压缩,默认关闭
      -XX:CMSFullGCsBeforeCompaction=8:执行多少次不压缩FullGC后,进行一次压缩,默认是0(代表每次FullGC都进行压缩)
      -XX:+UseCMSInitiatingOccupancyOnly:使用手动定义初始化定义开始,禁止hostspot自行触发CMS GC
      -XX:ParallelGCThreads=8:并行收集器的线程数,此值最好配置与处理器数目相等 同样适用于CMS
      日志参数:
      -XX:+HeapDumpOnOutOfMemoryError:当发生内存溢出时,进行堆内存dump-XX:+PrintGCDetails:打印GC的详细信息

    六、某测试环境服务器jvm配置示例(不能换行)

      -server -Xms1028m -Xmx1028m -XX:PermSize=256m -XX:MaxPermSize=256m -Xmn512m
      -XX:MaxDirectMemorySize=1g -XX:SurvivorRatio=10 -XX:+UseConcMarkSweepGC
      -XX:+UseCMSCompactAtFullCollection -XX:CMSMaxAbortablePrecleanTime=5000
      -XX:+CMSClassUnloadingEnabled -XX:CMSInitiatingOccupancyFraction=80
      -XX:+UseCMSInitiatingOccupancyOnly -XX:ParallelGCThreads=8
      -Xloggc:/home/admin/logs/gc.log -XX:+PrintGCDetails -XX:+PrintGCDateStamps
      -XX:+HeapDumpOnOutOfMemoryError-XX:HeapDumpPath=/home/admin/logs/java.hprof

  • 相关阅读:
    【数据结构】平衡二叉树之AVL树
    【数据结构】二叉排序树BST
    【数据结构】二叉树
    【算法】堆排序
    【数据结构】堆
    第五百八十一天 how can I 坚持
    第五百八十天 how can I 坚持
    第五百七十八、九天 how can I 坚持
    第五百七十七天 how can I 坚持
    第五百七十五、六天 how can I 坚持
  • 原文地址:https://www.cnblogs.com/qingyuu/p/11603607.html
Copyright © 2020-2023  润新知