一、maven 3.5 下载地址:http://maven.apache.org/download.cgihtml
二、下载了解压到java
三、配置环境变量web
四、测试看是否安装成功apache
五、maven配置(全局配置,用户配置)服务器
3.一、全局配置 oracle
在maven安装目录的conf里面有一个settings.xml文件,这个文件就是maven的全局配置文件。eclipse
该文件中配置来maven本地仓库的地址maven
默认在系统的用户目录下的m2/repository中,该目录是本地仓库的目录。ide
5.二、用户配置工具
用户配置文件的地址:~/.m2/settings.xml,该文件默认是没有,须要将全局配置文件拷贝一份到该目录下。
从新指定本地仓库地址,若是不指定,则默认是~/.m2/repository目录,若是用户配置文件不存在,则使用全局配置文件的配置。
-D 传入属性参数
-P 使用pom中指定的配置
-e 显示maven运行出错的信息
-o 离线执行命令,即不去远程仓库更新包
-X 显示maven容许的debug信息
-U 强制去远程参考更新snapshot包
例如 mvn install -Dmaven.test.skip=true -Poracle
其余参数能够经过mvn help 获取
一、mvn clean
说明: 清理项目生产的临时文件,通常是模块下的target目录
二、mvn package
说明: 项目打包工具,会在模块下的target目录生成jar或war等文件,以下运行结果。
生成的文件 以下:
三、mvn test
说明: 测试命令,或执行src/test/java/下junit的测试用例.
四、mvn install
说明: 模块安装命令 将打包的的jar/war文件复制到你的本地仓库中,供其余模块使用 -Dmaven.test.skip=true 跳过测试(同时会跳过test compile)
五、mvn deploy
说明: 发布命令 将打包的文件发布到远程参考,提供其余人员进行下载依赖 ,通常是发布到公司的私服,这里我没配置私服,因此就不演示了。
POM全称是Project Object Model,即项目对象模型。pom.xml是maven的项目描述文件,它相似与antx的project.xml文件。pom.xml文件以xml的 形式描述项目的信息,包括项目名称、版本、项目id、项目的依赖关系、编译环境、持续集成、项目团队、贡献管理、生成报表等等。总之,它包含了全部的项目 信息。
3.2.1. pom.xml的基本配置
[java] view plaincopy
modelVersion 描述这个POM文件是听从哪一个版本的项目描述符。
groupId 针对一个项目的广泛惟一识别符。一般用一个彻底正确的包的名字来与其余项目的相似名字来进行区分(好比:org.apache.maven)。
artifactId 在给定groupID 的group里面为artifact 指定的标识符是惟一的 , artifact 表明的是被制做或者被一个project应用的组件(产出物)。
version 当前项目产生的artifact的版本以上4个元素缺一不可,其中groupId, artifactId, version描述依赖的项目惟一标志。
[html] view plaincopy
project是pom.xml的根节点,至于其它元素请参考POM Reference
POM有3个很重要的关系:依赖、继承、合成。
2.1. 依赖关系
[html] view plaincopy
若是想依赖一个maven库中没有的一个jar包,方法很简单,就是先将此jar包使用如下的命令安装到本地maven库中:
mvn install:install-file -Dfile=my.jar -DgroupId=mygroup -DartifactId=myartifactId -Dversion=1
再把依赖关系加进去便可。
2.2. 继承关系
另外一个强大的变化, maven带来的是项目继承。
2.2.1. 定义父项目
[html] view plaincopy
packaging 类型,定义值为 pom用于定义为parent和合成多个项目。 固然咱们建立的maven项目的pom都继承maven的super pom, 若是想看项目(父或子)的彻底的pom结构,能够运行:
mvn help:effective-pom
一、mvn eclipse:eclipse
说明: 生成eclipse配置文件,导入到eclipse开放,若是是使用m2eclipse插件,则能够不用次命令.直接使用插件导入到eclipse进行开放
注:经过次命令生产的项目,须要在eclipse中配置M2_HOME的命令,指向你的本地仓库文件夹.
来看看生成的结果:。classpath就是字节码
二、mvn eclipse:m2eclipse
生成eclipse配置文件,该配置文件需依赖eclipse 中有m2eclipse
-DdownloadSources=true 下载依赖包的源码文件
-Declipse.addVersionToProjectName=true 添加版本信息到项目名称中
三、mvn eclipse:clean
清除eclipse的项目文件
看看文件内容,没有project文件 了
一、mvn jetty:run
说明: 能够直接用jetty的服务器运行 注:此命令只适用于war的模块,即web模块.
二、mvn archetype:generate
说明: 模块建立命令, 执行命令后,会提示选择建立项目的模版,这里选18(maven-archetype-quickstart)
后面会提示你输入groupId(包存放的路径):
eg:com.lin
提示输入artifactId(模块名称):
eg:test-core
提示输入version(版本):
1.0.0-SNAPSHOT
提示输入package(指项目中基本的包路径):
eg:com.lin
提示确认,回车便可
说明: 发行版本,可与scm工具集成,来提供版本管理.不等同与版本控制.容许是必须有goal.两个经常使用的goal以下:
一、mvn release:clean
清理release操做是遗留下来的文件
二、mvn release:branch
说明: 建立分支,会在分支下建立执行的分支路径
-DbranchName=xxxx-100317 分支中的名称
-DupdateBranchVersions=false 是否更新分支的版本信息,默认为false
-DupdateWorkingCopyVersions=false 是否更新主干的版本信息,默认为true
三、mvn release:prepare
建立标记,会有交互过程,提示tag中pom的版本及trunk下的新版本号,每一个模块都会询问,默认是最小版本号+1
-Dtag = 4.4.0 将在tags建立该名称文件夹
-DdryRun=true 检查各项设置是否正确,可作测试用,会产生一些修改的配置文件信息.
命令:
mvn release:perform
次命令会自动帮咱们签出刚才打的tag,而后打包,分发到远程Maven仓库中
一、mvn project-info-reports:dependencies
生成项目依赖的报表
二、mvn dependency:resolve
查看依赖
查看项目依赖状况
三、mvn dependency:tree
打印出项目的整个依赖树
四、mvn dependency:analyze
帮助你分析依赖关系, 用来取出无用, 重复依赖的好帮手
五、mvn install -X
追踪依赖的完整轨迹
六、生命周期
resource->compile->process-classes->process-test-resources->test-compile->test->prepare-package->package
resources:resources 绑定在resource处理阶段, 用来将src/main/resources下或者任何指定其余目录下的文件copy到输出目录中
resources:testResources 将test下的resources目录或者任何指定其余目录copy到test输出目录下
compiler:testCompile 将测试类编译(包括copy资源文件)
surefire:test 运行测试用例
jar:jar 打jar包
compile(编译范围)
compile是默认的范围;若是没有提供一个范围,那该依赖的范围就是编译范围。编译范围依赖在全部的classpath中可用,同时它们也会被打包。
provided(已提供范围)
provided依赖只有在当JDK或者一个容器已提供该依赖以后才使用。例如,若是你开发了一个web应用,你可能在编译classpath中须要可用的Servlet API来编译一个servlet,可是你不会想要在打包好的WAR中包含这个Servlet API;这个Servlet API JAR由你的应用服务器或者servlet容器提供。已提供范围的依赖在编译classpath(不是运行时)可用。它们不是传递性的,也不会被打包。
runtime(运行时范围)
runtime依赖在运行和测试系统的时候须要,但在编译的时候不须要。好比,你可能在编译的时候只须要JDBC API JAR,而只有在运行的时候才须要JDBC驱动实现。 test(测试范围) test范围依赖 在通常的 编译和运行时都不须要,它们只有在测试编译和测试运行阶段可用。 system(系统范围) system范围依赖与provided相似,可是你必须显式的提供一个对于本地系统中JAR文件的路径。这么作是为了容许基于本地对象编译,而这些对象是系统类库的一部分。这样的构件应该是一直可用的,Maven也不会在仓库中去寻找它。。若是你将一个依赖范围设置成系统范围,你必须同时提供一个systemPath元素。注意该范围是不推荐使用的(你应该一直尽可能去从公共或定制的Maven仓库中引用依赖)。