/** * -XX:+HeapDumpOnOutOfMemoryError -XX:MaxPermSize=2m */ public class PermGenSpace { public static void main(String[] args) { List<String> list = new ArrayList<String>(); int i=0; while(true){ list.add(String.valueOf(i++).intern()); } } } 2)堆溢出 java.lang.OutOfMemoryError: Java heap space 這部分用于存放類的實例。被緩存的實例(Cache)對象,大的map,list引用大的對象等等,都會保存于此。 堆內存會在jvm啟動時自動設置,初始值 -Xms為物理內存的1/64,最大值-Xmx為1/4;可以通過參數-Xmn、-Xms、-Xmx設置,一般-Xms和-Xmx不超過80%,-Xmn為-Xmx的1/4; Java代碼
/** * -XX:+HeapDumpOnOutOfMemoryError -Xms20m -Xmx20m -XX:MaxNewSize=10m */ public class HeapSpace { public static void main(String[] args) { List<String> list = new ArrayList<String>(); int i=0; while(true){ list.add(new String(""+i++)); } } } 3)java.lang.OutOfMemoryError: GC overhead limit exceeded JDK6新增錯誤類型。當GC為釋放很小空間占用大量時間時拋出。 Java代碼
/** * -XX:+HeapDumpOnOutOfMemoryError -Xms20m -Xmx20m -XX:MaxNewSize=256m */ public class HeapSpace { public static void main(String[] args) { List<String> list = new ArrayList<String>(); int i=0; while(true){ list.add(new String(""+i++)); } } } 可以添加JVM的啟動參數來限制使用內存:-XX:-UseGCOverheadLimit 4)棧溢出錯誤,非規范的OutOfMemoryError Exception in thread "main" java.lang.StackOverflowError 這部分用于存放局部變量、方法棧幀信息。棧幀太多,也就是函數調用層級過多時就會出現此異常,檢查是否有死遞歸的情況。 對應的啟動參數為:-Xss ( JDK1.5以后默認是1M,之前是256K) Java代碼
/** * -XX:+HeapDumpOnOutOfMemoryError -Xss(默認1M) */ public class StackOverflow { public int i=0; public void stackLeak(){ i++; stackLeak(); } public static void main(String[] args) { StackOverflow sof = new StackOverflow(); sof.stackLeak(); } } 實例,以下是1G內存環境下java jvm 的參數設置參考: JAVA_OPTS="-server -Xms800m -Xmx800m -XX:PermSize=64M -XX:MaxNewSize=256m -XX:MaxPermSize=128m -Djava.awt.headless=true 2、dump排查方案 jvm啟動時添加參數-XX:+HeapDumpOnOutOfMemoryError,這樣當內存溢出時,會生成dump文件: java.lang.OutOfMemoryError: Java heap space Dumping heap to java_pid5304.hprof ... Heap dump file created [85357895 bytes in 2.095 secs] 使用Memory Analyze分析,查看類使用情況; 3、分析工具1)動態分析,實時 : Jprofile2)靜態分析 ,需要dump文件: Eclipse Memory Analyzer等 參考:http://fangzhu19880123.CUOxin.com/blog/1129039新聞熱點
疑難解答