隨着項目的復雜程度的增加,一個項目中需要依賴的外部系統也在逐漸增多,在構建大的項目時,需要大內存的支持,此時Maven可能會報內存溢出(OutOfMemory)的異常,運行mvn命令實際上是執行了java命令,因為java默認的最大可用內存不能夠滿足Maven運行時的需要,解決的的辦法就是調整Java堆的大小。
1.報出的異常如下:
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)
2. 解決辦法:
1)在本機Maven的home目錄下找到mvn.bat文件,這個是Maven執行的腳本文件:
~Maven_home\bin\mvn.bat
2)編輯mvn.bat文件,在mvn.bat文件中找到有關mvn參數設置的注釋
@REM set MAVEN_OPTS=-Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
3)在此句注釋下面添加mvn內存設置的命令
set MAVEN_OPTS= -Xms128m -Xmx512m
此語句的意思是將java堆的大小范圍設置為128M-512M;
之后,當你運行Maven命令如 mvn -version 的時候,你會看到如下的輸出:
C:\Users\tu.lit>mvn -version
Apache Maven 2.2.1 (r801777; 2009-08-07 03:16:01+0800)
Java version: 1.6.0_10-rc2
Java home: C:\Program Files\Java\jdk1.6.0_10\jre
Default locale: zh_CN, platform encoding: GBK
OS name: "windows vista" version: "6.1" arch: "x86" Family: "windows"
4)保存mvn.bat文件,到工程目錄下重新編譯工程mvn install;