Mar*_*cel 10 java garbage-collection
昨天我们在一个JBoss应用服务器的服务器日志中输出了以下GC:
51628.286: [GC 51628.288: [ParNew: 1843200K->204800K(1843200K), 21.3196040 secs]
5177730K->3743415K(7987200K), 21.3217870 secs]
[Times: user=1.38 sys=0.33, real=21.32 secs]
Run Code Online (Sandbox Code Playgroud)
我理解这样的输出:年轻一代的大小为1843200K.前一代的尺寸为1843200K,尺寸在204800K之后.收集持续了21.3秒.
通常我们的年轻一代收藏持续时间<1秒.yg集合在哪种情况下持续这么久?
我们的JVM参数:
-server
-verbose:gc
-XX:+PrintGCTimeStamps
-XX:+PrintGCDetails
-XX:NewRatio=3
-XX:+UseConcMarkSweepGC
-XX:+UseParNewGC
-XX:+UseCMSCompactAtFullCollection
-XX:CMSInitiatingOccupancyFraction=60
-XX:MaxPermSize=256m
-Xss512k
-Xms8000m
-Xmx8000m
Run Code Online (Sandbox Code Playgroud)
java版本:
java version "1.6.0_29"
Java(TM) SE Runtime Environment (build 1.6.0_29-b11)
Java HotSpot(TM) 64-Bit Server VM (build 20.4-b02, mixed mode)
Run Code Online (Sandbox Code Playgroud)
谢谢,马塞尔
我们有一个tomcat服务器,垃圾收集持续约2分钟.最后,我们找到了原因,我们通过-Xmx为JVM分配了比系统上的物理内存更多的内存.这导致垃圾收集期间的分页,这会导致垃圾收集.
此外,我们有多个VM在同一台物理机器上运行.确保没有为所有VM分配比服务器上的物理内存更多的内存.
有关详细信息,请参阅调整内存管理系统,设置堆大小(我的重点)部分:
命令行选项:-Xms:-Xmx:
堆大小会影响分配速度,垃圾收集频率和垃圾收集时间.一小堆将很快变满,必须更频繁地进行垃圾收集.它也容易碎片化,使对象分配更慢.大堆在垃圾收集时间中引入了轻微的开销.必须将大于系统中可用物理内存的堆分页到磁盘,这会导致访问时间过长甚至应用程序冻结,尤其是在垃圾回收期间.
| 归档时间: |
|
| 查看次数: |
1474 次 |
| 最近记录: |