JVM调优技巧集锦

开发 后端
这里向大家描述一下JVM调优技巧,在升级JVM版本时,如果能使用64-bit,使用64-bitJVM,另外对JVM堆内的各个区域(young,old,perm)正确设置大小。

你对JVM调优的方法了解多少,这里和大家分享几个,比如要升级JVM版本,如果能使用64-bit,使用64-bitJVM。基本上没什么好解释的,很简单将JVM升级到***的版本。如果你还是使用JDK1.4甚至是更早的JVM,那你首先要做的就是升级。

JVM调优技巧总结

这篇是技巧性的文章,如果要找关于GC或者调整内纯的文章,看我其他几篇文章。因为是JVM调优总结,所以废话少说。从各方面一共收集到以下几个方法:

1.升级JVM版本。如果能使用64-bit,使用64-bitJVM。

基本上没什么好解释的,很简单将JVM升级到***的版本。如果你还是使用JDK1.4甚至是更早的JVM,那你首先要做的就是升级。因为JVM从1.4->1.5->1.6可不是仅仅的版本号升级,或者仅仅往里面加了一堆新的语言特性,这么简单。而是真正在JVM做了重大的改进,每次版本升级,都有巨大的性能升级。尤其是SUN认识到java是知己的全部的时候(夸张点,但连股票号都改成JAVA了,呵呵)。如果你经常逛SUN的JVM论坛,你就会发现实际上JVM上的毛病是这么多。如果你因为各种原因,而不能升级到1.6,那你可以升级到该版本的***版。

2.选择一个正确的GC(GargageCollection)。

由于当JAVA程序GC的时候,会停下当前程序。尤其FullGC的时候,会停留很长时间。一般对于GUI程序来说,是很难接受的(想想Eclipse暂停的时候)。JAVA5以后,开始自带了好几种GC,你可以选择一个适合你的种类。有以下四种SerialCollector,Parallelcollector,ConcurrentCollector,TrainCollector(废弃)。后面几种时候使用并行收集,所以理论上有效率更高(要求你有超过2CUP,但是现在多核开始普及了,呵呵)。提示:更改GC种类以后要适当挺高JVM的内存量。

3.正确设置内存大小。进行JVM调优时对JVM堆内的各个区域(young,old,perm)正确设置大小。

这个是最困难的调整,因为这个调整会直接影响GC的效率。而且由于各个程序的类型不用,所以没有一个通用的数据。除了几个常用规则以外,需要使用工具(jstat,jvmstat,jconsole等等)仔细调整。下面会提到几个常用的准则。通常使用一下几个参数调整-Xms-Xmx-XX:MaxPermSize。

3.1调高-XX:NewRatio(NewSize/MaxNewSize)的值,会减少younggc的次数,但会增加oldgc的时间。

3.2增加普通GC的方法(减小FullGC)。扩大young区域的大小(***40%),并过大Survivor的区域。使得更多的object留在younggen。


4.减小类的使用量,注意类的load和unload,减少JSP页数。

类实际上也是对象,会直接分配perm区域里,即使FullGC也会很少收集。JSP也会分配到perm区域里,效果同理。如果perm过大,超过XX:MaxPermSize值,会发生OutOfMemoryError:PermGenspace异常。解决方法是提高-XX:MaxPermSize值。

5.进行JVM调优时避免使用-Xnoclassgc

6.如果是RMI程序,要注意调整RMIDGC的时间。

◆以下是几个写程序时,应该注意的地方。也可减小GC,提高JVM性能。

1.不要使用System.gc()方法。

因为它会产生FullGC。

2.尽可能少分配大的临时对象(生命周期短的)

可能会直接分配到old区域里,old区域只有FullGC的时候会收集。

3.避免使用finalize()方法。

finalize()会增加GC的负担,使用java.lang.ref代替。
 

【编辑推荐】

  1. 全面认识JVM垃圾回收机制
  2. JVM工作原理和特点探究
  3. 探索Java工作原理之JVM内存回收
  4. 实例解析Linux平台的JVM性能评测
  5. 深入JVM:ClassLoader相关知识简介

 

 

责任编辑:佚名 来源: csdn.net
相关推荐

2010-09-25 13:05:07

JVM参数

2010-09-25 15:52:27

JVM内存JVM

2010-09-17 17:02:24

JVM参数

2012-01-10 14:35:08

JavaJVM

2017-07-21 08:55:13

TomcatJVM容器

2022-11-30 08:17:41

JVM调优技巧

2023-11-11 19:07:23

JVMJava

2020-12-30 15:06:39

开发技能代码

2010-09-26 13:39:46

JVM调优

2012-01-10 15:13:56

JavaJVM

2021-06-03 08:32:18

JVM调优虚拟机

2017-09-22 15:15:23

jvm调优命令

2017-10-17 14:02:30

jvm调优工具

2010-09-26 10:53:00

JVM内存调优设置

2023-11-10 11:23:20

JVM内存

2010-03-04 10:56:52

JVM参数

2021-11-21 23:03:38

jvm调优虚拟机

2010-09-27 09:23:42

JVM调优

2020-11-09 07:34:49

JVM性能监控

2023-04-24 14:54:09

JVM性能调优
点赞
收藏

51CTO技术栈公众号