maven-compiler-plugin
用于編譯項目源代碼。
compile目標會編譯src/main/java
目錄下的源代碼。
testCompile目標會編譯src/test/java
目錄下的測試代碼。
maven compile
編譯源代碼。
maven testCompile
編譯源代碼+測試代碼。
配置:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.6.0</version>
<configuration>
<source>1.8</source> <!-- 源代碼使用jdk1.8支持的特性 -->
<target>1.8</target> <!-- 使用jvm1.8編譯目標代碼 -->
<compilerArgs> <!-- 傳遞參數 -->
<arg>-parameters</arg>
<arg>-Xlint:unchecked</arg>
<arg>-Xlint:deprecation </arg>
</compilerArgs>
</configuration>
</plugin>
用戶可以通過兩種方式調用Maven插件目標。第一種方式是將插件目標與生命周期階段(lifecycle phase)綁定,這樣用戶在命令行只是輸入生命周期階段而已,例如Maven默認將maven-compiler-plugin的compile目標與compile生命周期階段綁定,因此命令mvn compile實際上是先定位到compile這一生命周期階段,然后再根據綁定關系調用maven-compiler-plugin的compile目標。第二種方式是直接在命令行指定要執行的插件目標,例如mvn archetype:generate 就表示調用maven-archetype-plugin的generate目標,這種帶冒號的調用方式與生命周期無關。
(轉自:http://www.infoq.com/cn/news/2011/04/xxb-maven-7-plugin)
maven-surefire-plugin
用于跑測試用例
此插件可以不在pom.xml里面聲明,maven運行命令時,會自動調用該插件。
一些有用的配置:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<skipAfterFailureCount>1</skipAfterFailureCount> <!-- 只要有一個用例測試失敗,就立即停止。默認情況下會跑完所有測試用例 -->
<rerunFailingTestsCount>2</rerunFailingTestsCount> <!-- 失敗重試次數 -->
<parallel>methods</parallel> <!-- 并發執行測試用例 -->
<threadCount>10</threadCount> <!-- 并發執行時的線程數量 -->
</configuration>
</plugin>
一些用法:
// 跳過測試用例
mvn test -Dmaven.test.skip=true
// 或
mvn test -DskipTests=true
// 運行指定的測試用例
mvn test -Dtest=*2Test
mvn test -Dtest=App2Test,AppTest
mvn test -Dtest=???2Test
mvn test -Dtest=*Test#testAdd
參考:
http://www.cnblogs.com/qyf404/p/5013694.html
spring-boot-maven-plugin
spring-boot開發必備插件。它能將spring-boot項目代碼及其依賴jar打包成一個完整的可執行的jar包(fat jar)作用和插件maven-shade-plugin
差不多。
repackage的goal綁定在生命周期的package階段。
使用方式:
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
如果指定了spring-boot作為parent,可以不指定版本和repackage goal
:
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.3.8.RELEASE</version>
<configuration>
<mainClass>${start-class}</mainClass>
</configuration>
</parent>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
spring-boot查找main文件的流程是:
- 首先查看
<mainClass>
是否有值,如果有,直接拿標簽內的類名作為入口。
<properties>
<start-class>com.example.Application</start-class>
</properties>
- 如果沒找到
<start-class>
標簽,會遍歷所有文件,找到注解了@SpringBootApplication
并含有main方法的類,將其作為入口。
實踐證明,如果沒有定義<start-class>
,查找入口類的方法也是非常快的。
在實際開發中,推薦手動定義<start-class>
。這樣在一個項目工程中可以有多個@SpringBootApplication
注解的類,修改一下pom里的配置就能靈活切換入口了。
maven 生命周期中及對應插件
maven生命周期是指從初始化,編譯,打包,發布的一系列過程。
maven生命周期有三類::clean,default,site。我們經常使用的是clean(負責清理項目)和default(負責構建項目)。
default生命周期包括以下phase(階段):
validate
initialize
generate-sources
process-sources
generate-resources
process-resources
compile
process-classes
generate-test-sources
process-test-sources
generate-test-resources
process-test-resources
test-compile
process-test-classes
test
prepare-package
package
pre-integration-test
integration-test
post-integration-test
verify
install
deploy
maven的default生命周期各個phase綁定的插件:
phase | 插件:goal |
---|---|
generate-resources | plugin:descriptor |
process-resources | resources:resources |
compile | compiler:compile |
process-test-resources | resources:testResources |
test-compile | compiler:testCompile |
test | surefire:test |
package | jar:jar and plugin:addPluginArtifactMetadata |
install | install:install |
deploy | deploy:deploy |
可以通過命令查看插件的詳細信息:
mvn help:describe -Dplugin=org.apache.maven.plugins:maven-compile-plugin –Ddetail
官方文檔:http://maven.apache.org/guides/introduction/introduction-to-the-lifecycle.html