jboss記憶體查看:
1. 用瀏覽器開啟網址:http://IP:port/jmx-console/
2. 找到 jboss.system 一節,或者在 filter 文字框中輸入 jboss.system 然後按下 ApplyFilter 按鈕
3. 找到 type=ServerInfo 節點並點擊進入
4. 找到 listMemoryPools() 方法,點擊其下的 Invoke 按鈕
一、java.lang.OutOfMemoryError: PermGen space
PermGen space的全稱是Permanent Generation space,是指記憶體的永久儲存地區,
這塊記憶體主要是被JVM存放Class和Meta資訊的,Class在被Loader時就會被放到PermGen space中,
它和存放類執行個體(Instance)的Heap地區不同,GC(Garbage Collection)不會在主程式運行期對
PermGen space進行清理,所以如果你的應用中有很多CLASS的話,就很可能出現PermGen space錯誤,
這種錯誤常見在web伺服器對JSP進行pre compile的時候。如果你的WEB APP下都用了大量的第三方jar, 其大小
超過了jvm預設的大小(4M)那麼就會產生此錯誤資訊了。
解決方案: 手動設定MaxPermSize大小
JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128m
建議:將相同的第三方jar檔案移置到server/all/lib目錄下,這樣可以達到減少jar 文檔重複佔用記憶體的目的。
二、java.lang.OutOfMemoryError: Java heap space
Heap size 設定
JVM堆的設定是指java程式運行過程中JVM可以調配使用的記憶體空間的設定.JVM在啟動的時候會自動化佈建Heap size的值,
其初始空間(即-Xms)是實體記憶體的1/64,最大空間(-Xmx)是實體記憶體的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等選項可
進行設定。Heap size 的大小是Young Generation 和Tenured Generaion 之和。
提示:在JVM中如果98%的時間是用於GC且可用的Heap size 不足2%的時候將拋出此異常資訊。
提示:Heap Size 最大不要超過可用實體記憶體的80%,一般的要將-Xms和-Xmx選項設定為相同,而-Xmn為1/4的-Xmx值。
解決方案:手動設定Heap size,修改啟動參數
JAVA_OPTS="-server -Xms800m -Xmx800m -XX:MaxNewSize=256m"
三、執行個體,以下給出1G記憶體環境下java jvm 的參數設定參考:
JAVA_OPTS="-server -Xms800m -Xmx800m -XX:PermSize=64M -XX:MaxNewSize=256m -XX:MaxPermSize=128m -Djava.awt.headless=true "
Windows
set JAVA_OPTS=%JAVA_OPTS% -Xms128m -Xmx256m -XX:PermSize=128m -XX:MaxPermSize=256m -XX:MaxNewSize=256m -Dfile.encoding=GBK
echo "JAVA_OPTS="$JAVA_OPTS
Linux
JAVA_OPTS="$JAVA_OPTS -Xms128m -Xmx256m -XX:PermSize=128m -XX:MaxPermSize=256m -XX:MaxNewSize=256m -Dfile.encoding=GBK"
echo "JAVA_OPTS="$JAVA_OPTS
JVM記憶體JAVA_OPTS參數說明
我經常會這樣來設定伺服器端的JVM:JAVA_OPTS="-server -Xms2048m -Xmx2048m -Xss512k"
-server:一定要作為第一個參數,在多個CPU時效能佳劉兵召寫於2008-12-25 12:40
-Xms:初始Heap大小,使用的最小記憶體,cpu效能高時此值應設的大一些
-Xmx:java heap最大值,使用的最大記憶體劉兵召寫於2008-12-25 12:40
上面兩個值是分配JVM的最小和最大記憶體,取決於硬體實體記憶體的大小,建議均設為實體記憶體的一半。劉兵召寫於2008-12-25 12:40
-XX:PermSize:設定記憶體的永久儲存地區劉兵召寫於2008-12-25 12:40
-XX:MaxPermSize:設定最大記憶體的永久儲存地區劉兵召寫於2008-12-25 12:40
-XX:MaxNewSize:劉兵召寫於2008-12-25 12:40
-Xss 15120 這使得JBoss每增加一個線程(thread)就會立即消耗15M記憶體,而最佳值應該是128K,預設值好像是512k.劉兵召寫於2008-12-25 12:40
+XX:AggressiveHeap 會使得 Xms沒有意義。這個參數讓jvm忽略Xmx參數,瘋狂地吃完一個G實體記憶體,再吃盡一個G的swap。劉兵召寫於2008-12-25 12:40
-Xss:每個線程的Stack大小劉兵召寫於2008-12-25 12:40
-verbose:gc 現實垃圾收集資訊劉兵召寫於2008-12-25 12:40
-Xloggc:gc.log 指定垃圾收集記錄檔劉兵召寫於2008-12-25 12:40
-Xmn:young generation的heap大小,一般設定為Xmx的3、4分之一劉兵召寫於2008-12-25 12:40
-XX:+UseParNewGC :縮短minor收集的時間劉兵召寫於2008-12-25 12:40
-XX:+UseConcMarkSweepGC :縮短major收集的時間劉兵召寫於2008-12-25 12:40
提示:此選項在Heap Size 比較大而且Major收集時間較長的情況下使用更合適。