JVM调优

个人在实际开发中总结的几条关于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调试是一个循序渐进的过程,要通过问题看本质,在开发中对于代码的优化也非常重要。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值