代碼如下 |
複製代碼 |
[INFO] Building jar: /home/dl9pf/svn/mindquarry/mindquarry-jcr/mindquarry-jcr-changes/target/mindquarry-migration-with-dependencies.jar [INFO] ------------------------------------------------------------------------ [ERROR] FATAL ERROR [INFO] ------------------------------------------------------------------------ [INFO] Java heap space [INFO] ------------------------------------------------------------------------ [INFO] Trace java.lang.OutOfMemoryError: Java heap space at java.lang.AbstractStringBuilder.expandCapacity(AbstractStringBuilder.java:99) at java.lang.AbstractStringBuilder.append(AbstractStringBuilder.java:518) ... at org.codehaus.classworlds.Launcher.launchEnhanced(Launcher.java:315) at org.codehaus.classworlds.Launcher.launch(Launcher.java:255) at org.codehaus.classworlds.Launcher.mainWithExitCode(Launcher.java:430) at org.codehaus.classworlds.Launcher.main(Launcher.java:375) [INFO] ------------------------------------------------------------------------ [INFO] Total time: 7 minutes 14 seconds [INFO] Finished at: Wed Sep 05 07:44:55 CEST 2007 [INFO] Final Memory: 37M/63M [INFO] ------------------------------------------------------------------------
|
解決的方法是調整java的堆大小的值。
Windows環境中
找到檔案%M2_HOME%binmvn.bat ,這就是啟動Maven的指令檔,在該檔案中你能看到有一行注釋為:
代碼如下 |
複製代碼 |
@REM set MAVEN_OPTS=-Xdebug -Xnoagent -Djava.compiler=NONE... |
它的意思是你可以設定一些Maven參數,我們就在注釋下面加入一行:
代碼如下 |
複製代碼 |
set MAVEN_OPTS= -Xms128m -Xmx512m
|
之後,當你運行Maven命令如 mvn -version 的時候,你會看到如下的輸出:
代碼如下 |
複製代碼 |
E:test>mvn -version E:test>set MAVEN_OPTS= -Xms128m -Xmx512m Maven version: 2.0.9 Java version: 1.6.0_07 OS name: "windows 2003" version: "5.2" arch: "x86" Family: "windows" |
我們看到,配置的Maven選項生效了,OutOfMemoryError也能得以相應的解決。
Linux環境中
也可以通過設定環境變數解決該問題, 如,編輯檔案 /etc/profile 如下
代碼如下 |
複製代碼 |
MAVEN_OPTS=-Xmx512m export JAVA_HOME MAVEN_HOME MAVEN_OPTS JAVA_BIN PATH CLASSPATH
|
如果你使用Hudson
用 Hudson + Maven做持續整合,並不幸也遇到了類似的錯誤,那麼上述兩種方式都將不再起作用了,因為Hudson使用自己的maven-agent來啟動Maven,不會去調用Maven的指令碼,自然相應的配置也就無效了。
好在Hudson也給為我們提供了配置點,在Hudson的項目配置頁面中,有一塊Build地區,這裡我們已經設定了Root Pom和Goals。注意該地區的右下角有一個"Advanced..."按鈕,點擊會看到MAVEN_OPTS輸入框,這裡輸入"-Xmx512m"就OK了。
m2eclipse中
類似以上的方法都會失效,所幸m2eclipse提供了配置點。步驟如下:
代碼如下 |
複製代碼 |
項目上右擊 -> Run As -> Run Configurations -> Maven Build 上右擊 -> New |
這時會看到一個maven回合組態對話方塊,這裡面其它的配置我不多解釋了,為瞭解決記憶體溢出的問題,我們可以選擇第二個TAB: JRE,然後在VM arguments中輸入配置如:-Xms128m -Xmx512m。