您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
免费发信息

基于JVM 调优的技巧总结分析

2024/3/28 16:02:56发布4次查看
这篇是技巧性的文章,如果要找关于gc或者调整内纯的文章,看我其他几篇文章。因为是jvm 调优总结,所以废话少说。从各方面一共收集到以下几个方法:
1.升级 jvm 版本。如果能使用64-bit,使用64-bit jvm。    
基本上没什么好解释的,很简单将jvm升级到最新的版本。如果你还是使用jdk1.4甚至是更早的jvm,那你首先要做的就是升级。因为jvm从1.4- >1.5->1.6可不是仅仅的版本号升级,或者仅仅往里面加了一堆新的语言特性,这么简单。而是真正在jvm做了重大的改进,每次版本升级,都有巨大的性能升级。尤其是sun认识到java是知己的全部的时候(夸张点,但连股票号都改成java了,呵呵)。如果你经常逛sun 的jvm论坛,你就会发现实际上jvm上的毛病是这么多。如果你因为各种原因,而不能升级到1.6,那你可以升级到该版本的最新版。
2.选择一个正确的gc(gargage collection)。
由于当java程序gc的时候,会停下当前程序。尤其full gc的时候,会停留很长时间。一般对于gui程序来说,是很难接受的(想想eclipse暂停的时候)。 java5 以后,开始自带了好几种gc,你可以选择一个适合你的种类。有以下四种serial collector,parallel collector,concurrent collector,train collector(废弃)。后面几种时候使用并行收集,所以理论上有效率更高(要求你有超过2cup,但是现在多核开始普及了,呵呵)。提示:更改gc 种类以后要适当挺高jvm的内存量。
3.正确设置内存大小。对jvm堆内的各个区域(young,old,perm)正确设置大小。
这个是最困难的调整,因为这个调整会直接影响gc的效率。而且由于各个程序的类型不用,所以没有一个通用的数据。除了几个常用规则以外,需要使用工具(jstat,jvmstat,jconsole等等)仔细调整。下面会提到几个常用的准则。通常使用一下几个参数调整-xms -xmx-xx:maxpermsize。
3.1 调高-xx:newratio(newsize/maxnewsize)的值,会减少young gc的次数,但会增加old gc的时间。
3.2 增加普通gc的方法(减小full gc)。扩大young区域的大小(最大40%),并过大survivor的区域。使得更多的object留在young gen。
4.减小类的使用量,注意类的load和unload,减少jsp页数。
类实际上也是对象,会直接分配perm区域里,即使full gc也会很少收集。jsp也会分配到perm区域里,效果同理。如果perm过大,超过xx:maxpermsize值,会发生 outofmemoryerror: permgen space异常。解决方法是提高-xx:maxpermsize值。
5.避免使用-xnoclassgc  
6.如果是rmi程序,要注意调整rmi dgc的时间。
以下是几个写程序时,应该注意的地方。也可减小gc,提高jvm性能。
1.不要使用system.gc()方法。
因为它会产生full gc。
2.尽可能少分配大的临时对象(生命周期短的)
可能会直接分配到old区域里,old区域只有full gc的时候会收集。
3.避免使用finalize()方法。
finalize()会增加gc的负担,使用java.lang.ref代替。
更多基于jvm 调优的技巧总结分析。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录