1. 程式人生 > >maven--學習(6)--MVN命令

maven--學習(6)--MVN命令

arc rgs 測試報告 額外 class sna osi tro 反向

Maven庫:

http://repo2.maven.org/maven2/

Maven依賴查詢:

http://mvnrepository.com/

一,Maven常用命令:

1. 創建Maven的普通Java項目:

mvn archetype:create
    -DgroupId=packageName
    -DartifactId=projectName

2. 創建Maven的Web項目:

mvn archetype:create
    -DgroupId=packageName
    -DartifactId=webappName
    -DarchetypeArtifactId=maven-archetype-webapp

3. 反向生成 maven 項目的骨架:

mvn archetype:generate

  你是怎麽創建你的maven項目的?是不是像這樣:

mvn archetype:create -DarchetypeArtifactId=maven-archetype-quickstart -DgroupId=com.ryanote -Dartifact=common

  如果你還再用的話,那你就out了,現代人都用mvn archetype:generate了,它將創建項目這件枯燥的事更加人性化,你再也不需要記那麽多的archetypeArtifactId,你只需輸入archetype:generate,剩下的就是做”選擇題”了.

  cmd步驟:

技術分享圖片

  縮寫寫法:

mvn archetype:generate -DgroupId=otowa.user.dao -DartifactId=user-dao -Dversion=0.01-SNAPSHOT

4. 編譯源代碼:

mvn compile

5. 編譯測試代碼:

mvn test-compile

6. 運行測試:

mvn test

7. 產生site:

mvn site

8. 打包:

mvn package

9. 在本地Repository中安裝jar:

mvn install
例:installing D:\xxx\xx.jar to D:\xx\xxxx

10. 清除產生的項目:

mvn clean

11. 生成eclipse項目:

mvn eclipse:eclipse

12. 生成idea項目:

mvn idea:idea

13. 組合使用goal命令,如只打包不測試:

mvn -Dtest package

14. 編譯測試的內容:

mvn test-compile

15. 只打jar包:

mvn jar:jar

16. 只測試而不編譯,也不測試編譯:

mvn test -skipping compile -skipping test-compile
 ( -skipping 的靈活運用,當然也可以用於其他組合命令) 

17. 清除eclipse的一些系統設置:

mvn eclipse:clean 

18.查看當前項目已被解析的依賴:

mvn dependency:list

19.上傳到私服:

mvn deploy

20. 強制檢查更新,由於快照版本的更新策略(一天更新幾次、隔段時間更新一次)存在,如果想強制更新就會用到此命令:

mvn clean install-U

21. 源碼打包:

mvn source:jar
或
mvn source:jar-no-fork

mvn compile與mvn install、mvn deploy的區別

  1. mvn compile,編譯類文件
  2. mvn install,包含mvn compile,mvn package,然後上傳到本地倉庫
  3. mvn deploy,包含mvn install,然後,上傳到私服

二,PS:

  一般使用情況是這樣,首先通過cvs或svn下載代碼到本機,然後執行mvn eclipse:eclipse生成ecllipse項目文件,然後導入到eclipse就行了;修改代碼後執行mvn compile或mvn test檢驗,也可以下載eclipse的maven插件。

1. 顯示版本信息 :

mvn -version/-v

2. 創建mvn項目:

mvn archetype:create -DgroupId=com.oreilly -DartifactId=my-app

3. 生成target目錄,編譯、測試代碼,生成測試報告,生成jar/war文件 :

mvn package

4. 運行項目於jetty上:

mvn jetty:run

5. 顯示詳細錯誤 信息:

mvn -e

6. 驗證工程是否正確,所有需要的資源是否可用:

mvn validate

7. 在集成測試可以運行的環境中處理和發布包:

mvn integration-test

8. 運行任何檢查,驗證包是否有效且達到質量標準:

mvn verify

9. 產生應用需要的任何額外的源代碼,如xdoclet :

mvn generate-sources

10. 使用 help 插件的 describe 目標來輸出 Maven Help 插件的信息:

mvn help:describe -Dplugin=help

11. 使用Help 插件輸出完整的帶有參數的目標列 :

mvn help:describe -Dplugin=help -Dfull

12. 獲取單個目標的信息,設置 mojo 參數和 plugin 參數。此命令列出了Compiler 插件的compile 目標的所有信息 :

mvn help:describe -Dplugin=compiler -Dmojo=compile -Dfull

13. 列出所有 Maven Exec 插件可用的目標:

mvn help:describe -Dplugin=exec -Dfull

14. 看這個“有效的 (effective)”POM,它暴露了 Maven的默認設置 :

mvn help:effective-pom

15. 想要查看完整的依賴蹤跡,包含那些因為沖突或者其它原因而被拒絕引入的構件,打開 Maven 的調試標記運行 :

mvn install -X

16. 給任何目標添加maven.test.skip 屬性就能跳過測試 :

mvn install -Dmaven.test.skip=true

17. 構建裝配Maven Assembly 插件是一個用來創建你應用程序特有分發包的插件 :

mvn install assembly:assembly

18. 生成Wtp插件的Web項目 :

mvn -Dwtpversion=1.0 eclipse:eclipse

19. 清除Eclipse項目的配置信息(Web項目) :

mvn -Dwtpversion=1.0 eclipse:clean

20. 將項目轉化為Eclipse項目 :

mvn eclipse:eclipse

21. mvn exec命令可以執行項目中的main函數 :

首先需要編譯java工程:mvn compile
不存在參數的情況下:mvn exec:java -Dexec.mainClass="***.Main"
存在參數:mvn exec:java -Dexec.mainClass="***.Main" -Dexec.args="arg0 arg1 arg2"
指定運行時庫:mvn exec:java -Dexec.mainClass="***.Main" -Dexec.classpathScope=runtime

22. 打印出已解決依賴的列表 :

mvn dependency:resolve

23. 打印整個依賴樹 :

mvn dependency:tree

在應用程序用使用多個存儲庫

技術分享圖片
<repositories>    
    <repository>     
        <id>Ibiblio</id>     
        <name>Ibiblio</name>     
        <url>http://www.ibiblio.org/maven/</url>   
    </repository>   
    <repository>     
        <id>PlanetMirror</id>     
        <name>Planet Mirror</name>     
        <url>http://public.planetmirror.com/pub/maven/</url>   
    </repository>  
</repositories>

mvn deploy:deploy-file -DgroupId=com -DartifactId=client -Dversion=0.1.0 -Dpackaging=jar -Dfile=d:\client-0.1.0.jar -DrepositoryId=maven-repository-inner -Durl=ftp://xxxxxxx/opt/maven/repository/
技術分享圖片

發布第三方Jar到本地庫中

mvn install:install-file -DgroupId=com -DartifactId=client -Dversion=0.1.0 -Dpackaging=jar -Dfile=d:\client-0.1.0.jar


-DdownloadSources=true

-DdownloadJavadocs=true

三,附加

mvn help:describe

你是否因為記不清某個插件有哪些goal而痛苦過,你是否因為想不起某個goal有哪些參數而苦惱,那就試試這個命令吧,它會告訴你一切的.

參數: 1. -Dplugin=pluginName 2. -Dgoal(或-Dmojo)=goalName:與-Dplugin一起使用,它會列出某個插件的goal信息,

如果嫌不夠詳細,同樣可以加-Ddetail.(註:一個插件goal也被認為是一個 “Mojo”)

下面大家就運行mvn help:describe -Dplugin=help -Dmojo=describe感受一下吧!

mvn tomcat:run

用了maven後,你再也不需要用eclipse裏的tomcat來運行web項目(實際工作中經常會發現用它會出現不同步更新的情況),只需在對應目錄裏運行 mvn tomat:run命令,然後就可在瀏覽器裏運行查看了.如果你想要更多的定制,可以在pom.xml文件裏加下面配置:

01 02 03 04 org.codehaus.mojo 05 tomcat-maven-plugin 06 07 /web 08 9090 09 10 11 12 當然你也可以在命令裏加參數來實現特定的功能,

下面幾個比較常用:

  1>. 跳過測試:-Dmaven.test.skip(=true)

  2>. 指定端口:-Dmaven.tomcat.port=9090

  3>. 忽略測試失敗:-Dmaven.test.failure.ignore=true 當然,如果你的其它關聯項目有過更新的話,一定要在項目根目錄下運行mvn clean install來執行更新,再運行mvn tomcat:run使改動生效.

mvnDebug tomcat:run

這條命令主要用來遠程測試,它會監聽遠程測試用的8000端口,在eclipse裏打開遠程測試後,它就會跑起來了,設斷點,調試,一切都是這麽簡單.上面提到的那幾個參數在這裏同樣適用.

mvn dependency:sources

故名思義,有了它,你就不用到處找源碼了,運行一下,你項目裏所依賴的jar包的源碼就都有了

maven--學習(6)--MVN命令