Sealyu

          --- 博客已遷移至: http://www.sealyu.com/blog

            BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            618 隨筆 :: 87 文章 :: 225 評(píng)論 :: 0 Trackbacks

          當(dāng)Maven項(xiàng)目很大,或者你運(yùn)行諸如 mvn site 這樣的命令的時(shí)候,maven運(yùn)行需要很大的內(nèi)存,在默認(rèn)配置下,就可能遇到j(luò)ava的堆溢出。如:

          [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] ------------------------------------------------------------------------

          解決的方法是調(diào)整java的堆大小的值。

          Windows環(huán)境中

          找到文件%M2_HOME%"bin"mvn.bat ,這就是啟動(dòng)Maven的腳本文件,在該文件中你能看到有一行注釋為:

            @REM set MAVEN_OPTS=-Xdebug -Xnoagent -Djava.compiler=NONE...

          它的意思是你可以設(shè)置一些Maven參數(shù),我們就在注釋下面加入一行:

          set MAVEN_OPTS= -Xms128m -Xmx512m

          之后,當(dāng)你運(yùn)行Maven命令如 mvn -version 的時(shí)候,你會(huì)看到如下的輸出:

          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選項(xiàng)生效了,OutOfMemoryError也能得以相應(yīng)的解決。

           

           

          Linux環(huán)境中

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

          MAVEN_OPTS=-Xmx512m
          export JAVA_HOME MAVEN_HOME MAVEN_OPTS JAVA_BIN PATH CLASSPATH

           

           

          如果你使用Hudson

          用 Hudson + Maven做持續(xù)集成,并不幸也遇到了類似的錯(cuò)誤,那么上述兩種方式都將不再起作用了,因?yàn)镠udson使用自己的maven-agent來(lái)啟動(dòng)Maven,不會(huì)去調(diào)用Maven的腳本,自然相應(yīng)的配置也就無(wú)效了。

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

           

          m2eclipse中

          類似以上的方法都會(huì)失效,所幸m2eclipse提供了配置點(diǎn)。步驟如下:

          項(xiàng)目上右擊 -> Run As -> Run Configurations -> Maven Build 上右擊 -> New

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

           


          還有一種說(shuō)法:

          編輯maven"bin中的mvn文件:

          • 在exec "$JAVACMD" "之后加上 -Xmx256m "即可。
          • 形式如:

              exec "$JAVACMD" "

            -Xmx256m "

          posted on 2010-01-19 08:55 seal 閱讀(395) 評(píng)論(0)  編輯  收藏 所屬分類: Maven
          主站蜘蛛池模板: 栾川县| 深泽县| 乐昌市| 黑龙江省| 林西县| 洞头县| 墨脱县| 德格县| 辽源市| 武汉市| 全州县| 五大连池市| 富阳市| 章丘市| 鲁山县| 贡嘎县| 镇远县| 平江县| 临夏市| 佛坪县| 靖边县| 临澧县| 泗洪县| 耿马| 平南县| 石狮市| 灌南县| 福贡县| 安吉县| 江油市| 庆安县| 荣昌县| 象山县| 宜城市| 郎溪县| 通城县| 通山县| 嘉鱼县| 贞丰县| 涿州市| 徐汇区|