首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

JVM内存储器参数设置

2012-10-26 
JVM内存参数设置JVM内存参数设置(A)PermGen space:全称是Permanent Generation space。就是说是永久保存的

JVM内存参数设置

JVM内存参数设置   (A)PermGen space:全称是Permanent Generation space。就是说是永久保存的区域,用于存放Class和Meta信息,Class在被Load的时候被放入该区域Heap space:存放Instance。(B)GC(Garbage Collection)应该不会对PermGen space进行清理所以如果你的APP会LOAD很多CLASS的话,就很可能出现PermGen space错误(1)Heap设定与垃圾回收Java Heap分为3个区,Young,Old和Permanent。Young保存刚实例化的对象。当该区被填满时,GC会将对象移到Old区。Permanent区则负责保存反射对象. (2)JVM的Heap分配可以使用-X参数设定, (9)+XX:AggressiveHeap会使得 Xms 1220m没有意义   -Xms 初始Heap大小  -Xmx java heap最大值 ,不应该超过物理内存的90% -Xmn young generation的heap大小   (3)JVM有2个GC线程。第一个线程负责回收Heap的Young区。第二个线程在Heap不足时,遍历Heap,将Young 区升级为Older区。Older区的大小等于-Xmx减去-Xmn,不能将-Xms的值设的过大,因为第二个线程被迫运行会降低JVM的性能。(4)如果你发现每次GC后,Heap的剩余空间会是总空间的50%,这表示你的Heap处于健康状态。许多Server端的Java程序每次GC后最好能有65%的剩余空间(5)Server端JVM最好将-Xms和-Xmx设为相同值。为了优化GC,最好让-Xmn值约等于-Xmx的1/3[2]。(6)一个GUI程序最好是每10到20秒间运行一次GC,每次在半秒之内完成[2]。(7)Stack的设定每个线程都有他自己的Stack。 -Xss 每个线程的Stack大小,最佳值应该是128K,默认值好像是512k. Stack的大小限制着线程的数量。如果Stack过大就好导致内存溢漏。-Xss参数决定Stack大小,例如-Xss1024K。如果Stack太小,也会导致Stack溢漏。(8)修改deploy/jbossweb-tomcat55.sar/service.xml将maxThreads根据目前的访问量由默认的250降为75,并使用jboss 4默认未写在标准service.xml里面而jboss 3写入了的2个参数: maxSparseThreads=55
http://zhidao.baidu.com/question/42973628.html

1 楼 dxm1986 2011-05-04   -Xss 每个线程的Stack大小,最佳值应该是128K,默认值好像是256k.

热点排行