Weblogic常見內存溢出問題解決方案

Java內存結構

Java Memory Model
參考鏈接:http://ifeve.com/under-the-hood-runtime-data-areas-javas-memory-model/

解決方案

java.lang.OutOfMemoryError: Java heap space

問題原因

指定的Java heap space過小

解決方案

修改weblogic安裝目錄\user_projects\domains\XXX_domain\bin\setDomainEnv.cmd的如下配置:

if "%JAVA_VENDOR%"=="Sun" (
    set WLS_MEM_ARGS_64BIT=-Xms256m -Xmx512m
    set WLS_MEM_ARGS_32BIT=-Xms256m -Xmx512m
) else (
    set WLS_MEM_ARGS_64BIT=-Xms512m -Xmx512m
    set WLS_MEM_ARGS_32BIT=-Xms512m -Xmx512m
)

根據當前配置文件指定的JVM廠商(如BEA、HP、IBM、Sun等),以及JVM是否運行在64位模式(JAVA_USE_64BIT),在恰當的位置修改配置;否則可能會因爲修改了無效的配置而不能解決問題。

java.lang.OutOfmemoryError: PermGen Space

問題背景

PermGen Space的全稱是Permanent Generation Space,是指內存的永久保存區域。這一部分用於存放class和meta的信息,class在加載的時候被放入PermGen Space區域。它和存放instance的heap區域不同,GC(Garbage Collection)不會在主程序運行期對PermGen Space進行清理。所以如果某個應用需要加載很多class,就有可能出現PermGen Space錯誤。
2014年3月發佈的Java 8刪除了HotSpot JVM中的永生代內存(PermGen,永生代內存主要用於存儲一些需要常駐內存、通常不會被回收的信息),而是改爲使用本地內存來存儲類的元數據信息,並將之稱爲:元空間(MetaSpace),這意味着以後不會再遇到java.lang.OutOfmemoryError: PermGen Space錯誤。

問題原因

指定的PermGen Space過小

解決方案

修改weblogic安裝目錄\user_projects\domains\XXX_domain\bin\setDomainEnv.cmd的如下配置:

set MEM_PERM_SIZE_64BIT=-XX:PermSize=128m

set MEM_PERM_SIZE_32BIT=-XX:PermSize=128m

if "%JAVA_USE_64BIT%"=="true" (
    set MEM_PERM_SIZE=%MEM_PERM_SIZE_64BIT%
) else (
    set MEM_PERM_SIZE=%MEM_PERM_SIZE_32BIT%
)

set MEM_MAX_PERM_SIZE_64BIT=-XX:MaxPermSize=256m

set MEM_MAX_PERM_SIZE_32BIT=-XX:MaxPermSize=256m

if "%JAVA_USE_64BIT%"=="true" (
    set MEM_MAX_PERM_SIZE=%MEM_MAX_PERM_SIZE_64BIT%
) else (
    set MEM_MAX_PERM_SIZE=%MEM_MAX_PERM_SIZE_32BIT%
)

weblogic容器內存溢出

上面介紹的是修改部署在weblogic容器上domain的JVM配置,只能解決domain內存溢出的問題。如果是weblogic容器本身內存溢出,則可以進一步修改weblogic容器本身的JVM配置。
修改weblogic安裝目錄\wlserver_X.X\common\bin\commEnv.cmd的如下配置:

@rem set up JVM options
if "%JAVA_VENDOR%" == "Oracle" goto oracle
if "%JAVA_VENDOR%" == "Sun" goto sun

goto continue

:oracle
if "%PRODUCTION_MODE%" == "true" goto oracle_prod_mode
set JAVA_VM=-jrockit
set MEM_ARGS=-Xms128m -Xmx256m
set JAVA_OPTIONS=%JAVA_OPTIONS% -Xverify:none
goto continue
:oracle_prod_mode
set JAVA_VM=-jrockit
set MEM_ARGS=-Xms128m -Xmx256m
goto continue


:sun
if "%PRODUCTION_MODE%" == "true" goto sun_prod_mode
set JAVA_VM=-client
set MEM_ARGS=-Xms32m -Xmx200m -XX:MaxPermSize=128m -XX:+UseSpinning
set JAVA_OPTIONS=%JAVA_OPTIONS% -Xverify:none
goto continue
:sun_prod_mode
set JAVA_VM=-server
set MEM_ARGS=-Xms32m -Xmx200m -XX:MaxPermSize=128m -XX:+UseSpinning
goto continue

驗證方法

domain啓動的時候會將JVM配置輸出到控制檯,可以據此驗證修改的JVM配置是否生效。

JAVA Memory arguments: -Xms256m -Xmx512m -XX:CompileThreshold=8000 -XX:PermSize=128m  -XX:MaxPermSize=256m
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章