2009年3月15日星期日

WLS_037:常见故障之五:Out of Memory

此种类型的故障需要对Java 内存管理有一定的了解,不清楚的人可以参考《Java 内存管理》。

1. WebLogic Server 如何使用内存?
1.1 WebLogic Server启动时,有两个参数可以设置Java Heap的大小:
(1)-Xms:Heap的最小值。默认是物理内存的1/64,最大1G。
(2)-Xmx:Heap的最大值。默认是物理内存的1/4,最大1G。
一般情况下,为了优化,将最小值和最大值设为一样。

1.2 在WebLogic Server中,出现Native 代码的地方将会使用Native Heap Memory:
(1)WebLogic Server native performance packs
(2)Type 2 JDBC drivers
(3)应用程序代码使用Java Native Interface (JNI)调用Native libraries
(4)JVM 自身

2. 产生原因
了解了WebLogic Server使用的内存类型之后,当出现Out of memory时,无非是
(1)内存的确不够用。
(2)内存不断泄漏,最终导致Out of memory。

3. 诊断步骤
(1)启动时加上-verbosegc参数,观察GC情况,尤其关注是否频繁Full GC,并且每次Full GC 回收的内存数量非常少(< 1M),这就说明内存的确不够用。
(2)使用JRockit Mission Control 查看内存使用情况

4. 如何模拟Out of Memory
(1)编写一个Java 类,每创建一个该类的实例,就消耗1M的内存(利用byte[])。
(2)编写一个Java Servlet,界面输入参数:多少M。有多少M即创建多少个(1)中的Java实例。
(3)观察Heap的使用情况(这里使用WLS8.1):[Server] > Monitoring > Performance


当JVM98%的时间用于GC,并且可用的Heap空间不足2%的时候,将会抛出java.lang.OutOfMemoryError。

没有评论: