零零碎碎
scope
compile:默认的scope。对编译、测试、运行有效。
test:只对编译测试代码及运行测试有效。编译主代码及运行无效。
provided:对编译(主代码及测试代码)和运行测试有效,但是运行时无效,如servlet-api。
runtime:测试和运行有效,对编译主代码无效(不明白。。。)
system:显式依赖指定的jar包。
<dependency>
<groupId>xxx</groupId>
<version>…</version>
<scope>system</scope>
<systemPath>${java.home}/lib/rt.jar</systemPath>
</dependency>
依赖调解
1. 路径最短优先
如A -> B -> C -> D(1.0), A -> E -> D(2.0),会依赖D(2.0)
2. 如果路径一样长,则按声明次序优先。
归类依赖
像logback, slf4j-api这种,一旦依赖,版本一般都是一致的。因此可以定义:
<properties>
<log.version>1.0</log.version>
</properties>
依赖时:
<dependency>
<groupId>xxx.logback-classic</groupId>
<version>${log.version}</version>
…
强行从中央仓库下载依赖
mvn org.apache.maven.plugins:maven-dependency-plugin:2.8:get -Dartifact=com.taobao.treasuregti:treasuregti-client:1.0.0-SNAPSHOT
已解析依赖
mvn dependency:list
依赖分析
mvn dependency:analyze
会解析出used undeclared dependencies以及unused declared dependencies
三套生命周期
clean:清理项目
default:构建项目
site:建立项目站点
插件
一个插件通常都有多个目标。如maven-dependency-plugin包含了:analyze, tree, list等目标。
mvn dependency:tree 冒号前是插件名,后面是目标。
maven生命周期与插件绑定,以完成实际的构建任务。如mvn test对应于surefire插件的test目标。
pluginManagement
与dependencyManagement一样,可以在主pom中定义,被子工程复用。
跳过测试
mvn install -DskipTests
跳过测试(包括测试代码的编译)
mvn install -Dmaven.test.skip=true
指定只运行特定的测试
mvn test -Dtest=Class1,Class2…
(也可以用*进行匹配)
使用maven-shade-plugin生成MANIFEST
生成jar包时,有时想直接通过java -jar来执行某个类的main方法。但是默认的jar包,是不支持的,因为没有MANIFEST文件以及未指定mainClass,可以通过shade plugin来配置
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>1.4</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<transformers>
<transformer
implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
<mainClass>YourMainClass</mainClass>
</transformer>
</transformers>
</configuration>
</execution>
</executions>
</plugin>
使用cargo plugin自动化部署到tomcat等容器中(也可以部署到远程容器)