傻子一個

          一路走來~~

           

          轉:解決Maven中OutOfMemory錯誤

          轉自:http://juvenshun.javaeye.com/blog/240257

          ---------------------------------------------------------------------------

          解決Maven中OutOfMemory錯誤

          關鍵字: maven outofmemoryerror

          當Maven項目很大,或者你運行諸如 mvn site 這樣的命令的時候,maven運行需要很大的內存,在默認配置下,就可能遇到java的堆溢出。如:

          [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環(huán)境中

          找到文件%M2_HOME%\bin\mvn.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環(huán)境中

          也可以通過設置環(huán)境變量解決該問題, 如,編輯文件 /etc/profile 如下

          MAVEN_OPTS=-Xmx512m
          export JAVA_HOME MAVEN_HOME MAVEN_OPTS JAVA_BIN PATH CLASSPATH

           

           

          如果你使用Hudson

          用 Hudson + Maven做持續(xù)集成,并不幸也遇到了類似的錯誤,那么上述兩種方式都將不再起作用了,因為Hudson使用自己的maven-agent來啟動Maven,不會去調用Maven的腳本,自然相應的配置也就無效了。

          好在Hudson也給為我們提供了配置點,在Hudson的項目配置頁面中,有一塊Build區(qū)域,這里我們已經 設置了Root Pom和Goals。注意該區(qū)域的右下角有一個"Advanced..."按鈕,點擊會看到MAVEN_OPTS輸入框,這里輸入"-Xmx512m"就 OK了。

           

          m2eclipse中

          類似以上的方法都會失效,所幸m2eclipse提供了配置點。步驟如下:

          項目上右擊 -> Run As -> Run Configurations -> Maven Build 上右擊 -> New

          這時會看到一個maven運行配置對話框,這里面其它的配置我不多解釋了,為了解決內存溢出的問題,我們可以選擇第二個TAB: JRE,然后在VM arguments中輸入配置如:-Xms128m -Xmx512m。

          posted on 2009-06-10 09:01 老文 閱讀(897) 評論(0)  編輯  收藏 所屬分類: Maven


          只有注冊用戶登錄后才能發(fā)表評論。


          網站導航:
           

          導航

          常用鏈接

          留言簿(2)

          隨筆分類(29)

          收藏夾(1)

          My Work

          學習文章

          軟件使用

          最新隨筆

          最新評論

          主站蜘蛛池模板: 武鸣县| 洛宁县| 大姚县| 隆昌县| 南平市| 中超| 宜阳县| 龙陵县| 浑源县| 永和县| 扎赉特旗| 木兰县| 盱眙县| 内黄县| 浦北县| 平舆县| 临澧县| 邛崃市| 洪江市| 固阳县| 平安县| 公安县| 游戏| 阆中市| 盐城市| 卢龙县| 新野县| 佳木斯市| 喀喇沁旗| 尖扎县| 大庆市| 中山市| 合水县| 定远县| 揭东县| 双桥区| 津南区| 马边| 广宗县| 安国市| 大化|