jvm性能调优

目的:较小的内存获得高的吞吐量或者低延迟;
jvm问题:cpu load过高,请求延迟,tps降低,内存泄漏;
CAP原则:同时内存小,延迟低,高吞吐不可能;
调优的依据:系统运行日志,堆栈错误信息,gc日志,线程快照,堆转储快照。

堆栈错误信息:outofmemoryerror:java heap space,堆内存溢出,stackoverflowerror栈溢出,outofmemoryerror:PermGen space方法区溢出

当老年代内存过小时可能引起频繁Full GC,当内存过大时Full GC时间会特别长。
物理内存一定的情况下,新生代设置越大,老年代就越小,Full GC频率就越高,但Full GC时间越短;相反新生代设置越小,老年代越大,Full GC的频率越低,每次Full GC消耗的时间越大。

jvm配置
1.-Xmx和-Xmx的值设置成相等,堆内存默认为-Xms指定的大小,默认空闲堆内存小于40%时,jvm扩大堆到-Xmx指定的大小;空闲堆内存大于70%时,jvm减少堆到-Xmx指定的大小。如果在Full GC后满足不了内存需求会动态调整。
2.新生代设置大一些,让对象在新生代多存活一段时间,每次Minor GC都要尽可能多的收集垃圾对象,防止或延迟对象进入老年代的机会,减少应用程序发生Full GC的频率。
3.老年代如果使用CMS收集器,新生代可以不用太大,因为CMS的并行收集速度也很快,收集过程比较耗时的并发标记和并发清楚阶段都可以与用户线程并发执行。
4方法去大小的设置

代码实现:
1.避免创建过大的对象及数组:过大的对象或数组在新生代没有足够空间容纳时会直接进入老年代,如果的短命的大对象,会提前触发Full GC。
2.避免加载大量数据。
3.当集合中有对象的引用,这些对象使用完之后尽快把集合中的引用清空,这些无用对象尽快回收避免进入老年代。
4.可以在合适的场景采用软引用、弱引用。
5.尽量避免长时间等待外部资源(数据库、网络、设备资源)的情况,缩小对象的生命周期,避免进入老年代,如果不能及时返回结果,可以适当采用异步处理的方式。

jvm参数:
-Xms初始堆大小
-Xmx最大堆大小
-Xmm新生代内存大小
-XX:NewRatio=n 设置新生代和年老代的比值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值