JVM调优

来源:互联网 发布:yy批量挂机软件 编辑:程序博客网 时间:2024/06/10 20:22

个人在实际开发中总结的几条关于JVM调优的办法分享给大家

常用命令:jps -v 输出虚拟机启动时的jvm参数
          jstat -gc监视堆内存运行状况

1.栈内存Stack特点空间比较小,速度快,用来存放对象的引用及程序中的基本类型,堆内存Heap的特点空间比较大,速度慢,一般对象都在这里生成、使用和消亡。
栈空间是有线程开辟的,线程结束栈空间由JVM回收,当程序运行所需超过栈内存的容量时会报StackOverflowError错误,通过java -Xss设置栈内存的大小,堆内存的大小不能太随意,设置最小堆内存为1G,最大为1.5G java -Xmx1536m -Xms1024m
2.垃圾收集器采用的是分代回收,堆内存包括新生代、老年代、永久代,新生成的对象都在新生代,新生代分为三个区Eden、

Survivor0、Survivor1,当S0和S1两个区都满了将把还要被使用的对象转移到老年代,当老年代的空间满了垃圾回收器将进行Full GC(jvm会停止所有的执行,把所有的资源给垃圾回收器)检查所有的对象,看是否有可以回收的对象,如果没有会报OutOfMemoryError错误。
新生代和老年代的内存大小比例为1:3左右,通过设置
java -XX:NewSize=32m -XX:MaxNewSize=640m -XX:MaxPermSize=1280m -XX:NewRatio=5
新生代最小内存32m最大内存640m,老年代最大内存1280m,新生代老年代的比例为1:5

3.大对象直接进入老年代

大对象是指需要大量连续内存空间的java对象,最典型的例子就是那些很长的String字符串及数组,经常出现大对象会提前触发垃圾收集以获取更多的内存空间存放这些大对象,虚拟机提供了一个XX:PretenureSizeThreshold参数,使大于这个参数的对象直接进入老年代,这样做是为了避免在新生代的Eden去和SO、S1之间发生大量的内存拷贝(新生代采用复制算法收集内存)。
4.变更GC的垃圾回收策略
java -XX:+UseParallelGC -XX:ParalleclGCThreads=20
采用并行垃圾回收机制,执行垃圾回收的最大线程数20(默认使用串行SerialGC,执行线程数等于CPU的数量),减少垃圾回收对系 统的影响,有利于提高系统性能。

JVM调试是一个循序渐进的过程,要通过问题看本质,在开发中对于代码的优化也非常重要。

 

 

0 0
原创粉丝点击