一个Java服务程序是否需要设置JVM参数

来源:百度知道 编辑:UC知道 时间:2024/06/14 16:16:55
例如最少内存,最大内存,因为我的服务程序要用内存保存大量数据,因为经常性的抛出内存溢出的问题。

兄台要的:
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 每个线程的Sta