为了账号安全,请及时绑定邮箱和手机立即绑定

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

/ 猿问

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

月关宝盒 2018-10-14 14:09:49

例如最少内存,最大内存,因为我的服务程序要用内存保存大量数据,因为经常性的抛出内存溢出的问题。

查看完整描述

1 回答

?
天涯尽头无女友

兄台要的:
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



查看完整回答
反对 回复 2018-11-08

添加回答

回复

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信