教程
IDE设置121
IntelliJ,Edit Configurations中添加maven,选中 Resolve Workspace artifacts能自动编译依赖模块
内置命令
- mvn install 将打好包的文件更新到本地库中 -X 强制重新更新
- mvn clean 清理生成的文件
- mvn compile 编译项目
- mvn test 运行测试
- mvn site 生成文档
- mvn validate 验证项目正确性
- mvn dependency:tree 显示依赖树
- mvn dependency:list 查看当前项目已解析依赖
- mvn help:effective-pom 显示当前模块有效pom
- mvn install -pl test 在test模块执行instal命令
参数
-P profile-name 使用某个profile构建
替换默认中行仓库
maven安装目录 conf/setting.xml,或者修改用户配置~/.m2/setting.xml
mirrors加入
<mirror>
<id> maven-net-cn</id>
<name> Maven China Mirror</name>
<url>http://127.0.0.1:8081/nexus/content/groups/public/</url>
<mirrorOf>central</mirrorOf>
</mirror>
mirrorOf,表示只为central仓库做镜像,如果想为所有的仓库做镜像那么可以改为:
<mirrorOf>*</mirrorOf>
elcipse中需要在maven设置中指定配置
依赖
依赖范围
- compile 编译范围,对编译,测试,运行三种classpath都有效
- test 只在测试范围classpath有效
- provided 在编译,测试范围有效,运行时无效
- runtime 运行时依赖范围,对于测试和运行有效,编译无效,典型例子JDBC驱动实现
- system 和provided依赖范围一致,但需要通过systemPath制定依赖文件路径
传递性依赖
假设A依赖B,B依赖C,B对A为第一直接依赖,C对B为第二直接依赖,C对A为传递性依赖
传递性依赖在第一直接依赖为compile时,和第二直接依赖一样,其他情况都和第一直接依赖一样
见下表,竖列是第一直接依赖范围,横列为第二直接依赖
依赖调解
- maven依赖调解第一原则:最短路径优先
- maven依赖调解第二原则:路径一样长的情况,第一声明者优先
如果有这样的依赖关系A -> B -> C -> X(1.0) A -> D -> X(2.0),2.0的会被使用
如果路径一样长,第一声明的优先使用
可选依赖
optional属性,含有optional的组件,被依赖时,optional的组件不会被传递,比如组件支持多个jdbc数据源,但使用时只用一个
一般情况不应该使用可选依赖,应该新建多个artifact,实现不同数据源的支持
依赖编译
-am --also-make 同时构建所列模块的依赖模块
-amd -also-make-dependents 同时构建依赖于所列模块的模块
-pl --projects <args> 构建指定的模块,模块间用逗号分隔
-rf -resume-from <args> 从是指定的模块恢复反应堆
mvn install -pl mealkey-web -am 编译mealkey-web 模块和依赖模块