- 概述
- Maven的目标
- 对Maven的错误理解
- Maven的版本
- Maven的安装
- Windows 2000/xp下的安装
- 基于Unxi-based的操作系统(Linux,Solaris and Mac OS X)
- 查看依赖库的位置
http://mvnrepository.com/ - Maven主要功能
- 构建项目
- web项目
- java应用程序
- Maven项目的标准目录介绍
- 项目构建的生命周期的介绍
- pom.xml介绍
- 文档编制
- 文档创建:
- 文档格式
- 文档国际化
- 报告设置
- 依赖管理
- 配置管理
- 持续集成工具continuum
- 安装
- 添加一个项目到continuum
- 配置管理信息(The SCM information)
- 开发者信息(The developers)
- 集成后所有的通知人信息(The notifiers)
- 构建工程
- 发布管理
- 配置
- 运行发布的命令
- Maven和eclipse工具的合作
- Eclipse插件mavenide
- 心得体会
- 扬长避短使用Maven 2
- 架设私服
- 结合Ant
- 定义meta-inf的信息
- 不要使用maven2相关的ide插件
- 依赖关系要设计好
- Maven中的中文编码问题
- Maven2主要配置文件
- maven2具体应用
- Maven指南
- 另一个Maven2简明教程
- 安装和配置
把maven-2.0.4-bin.zip解压到D:maven-2.0.4。
下面就是配置环境变量了,这和1.0的版本是一样的。(1)MAVEN_HOME:D:maven-2.0.4 (2)在Path 中加入%MAVEN_HOME%bin - 生命周期的引入
在Maven2中有了明确的生命周期概念,而且都提供与之对应的命令,使得项目构建更加清晰明了。主要的生命周期阶段: - 新增Dependency Scope
在POM 4中,<dependency>中还引入了<scope>,它主要管理依赖的部署。目前<scope>可以使用5个值: - 配置
- 常用goal
- 配置存储库
- 一些小问题
- M2_REPO的问题
- POM.XML 继承的写法
- 如何安装Jar(或war)依赖到本地的数据仓库中?
- maven2命令大全
- 结合Maven2进行J2EE项目构建
- Maven2 的新特性
- maven 配置篇 之 settings.xml
- maven 配置篇 之pom.xml
概述¶
Maven 最初的目的是在Jakarta Turbine项目中使构建处理简单化。几个项目之间使用到的Ant build文件差异很小,各个JAR都存入CVS。因此希望有一个标准的方法构建各个工程,清晰的定义一个工程的组成,一个容易的方法去发布项目信息并且 去提供一种在各个项目之间共享JAR包。
结果出现了一种功能能用于构建和管理任何基于java的工程。Maven小组希望他们已经做到了一些事情,这将有助于Java开发者更容易的完成每天的工作并且有助于理解任何基于java的项目。
Maven的目标¶
- 使构建过程更容易
- 提供统一构建系统
- 提供高质量的项目信息
- 提供开发的最佳实践指南
- 能无缝的加入新的特性
对Maven的错误理解¶
- Maven是一个站点和文档制作工具。
- Maven扩展了Ant,使其能下载到各种依赖包
- Maven是一系列可重用的Ant脚本
Maven的版本¶
Maven现在主要有Maven 1.x和Maven 2.x,其中现在最新版本是Maven 2.02。
Maven 2完成了对Maven 1的重写。重写的首要目的是要提供了强大的Jave构建和包含API的项目,允许Maven被植入任何地方,尤其是高级别的产品如IDEs、质量工具、报告工具等这些。Maven 2构建生命周期的概念正式化,其比Maven更易扩展。
因此现在我们主要研究的就是Maven 2。
Maven的安装¶
Windows 2000/xp下的安装¶
- 解压缩maven-2.0.2-bin.zip到你希望安装Maven 2.0.2的所在目录。这里假设你选择了C:\ProgramFiles\Apache Software Foundation\maven-2.0.2.
- 将C:\Program Files\Apache Software Foundation\maven-2.0.2\bin目录加入到你的%path%环境变量中。
- 同时,确认JAVA_HOME是否正确设置成功。
- 运行 mvn --version 确认是否安装成功。
显示Maven version: 2.0.2 则表示安装成功。
基于Unxi-based的操作系统(Linux,Solaris and Mac OS X)¶
- 解压缩发布包到你希望安装Maven 2.0.2的所在目录。这里假设你选择了/usr/local/maven-
- 将/usr/local/maven-2.0.2/bin目录加入到你的path环境变量中,例如:PATH=/usr/local/maven-2.0.2y/bin: $PATH。
- 同时,确认JAVA_HOME是否正确设置成功。
- 运行 mvn --version 确认是否安装成功。
显示Maven version: 2.0.2 则表示安装成功。
查看依赖库的位置
http://mvnrepository.com/¶
Maven主要功能¶
Maven是一种对项目的管理工具,它提供了一种方式来管理以下项目中涉及到的工作内容,同时以下也是Maven的主要功能:
- 构建项目(Builds)
- 文档编制(Documentation)
- 报告(Reporting)
- 依赖管理(Dependencies)
- 配置管理(SCMs)
- 发布管理(Releases)
构建项目¶
首先创建一个Maven工程。Maven可用于构建java应用工程和java web应用工程。
web项目¶
mvn archetype:create -DgroupId=com.mycompany.app -DartifactId=my-webapp -DarchetypeArtifactId=maven-archetype-webapp
目录结果如下:
my-webapp
|-- pom.xml
`-- src
`-- main
|-- webapp
| |-- WEB-INF
| | `-- web.xml
| `--index.jsp
`-- resources
其他的目录则需要自己补充。
其pom.xml文件内容如下:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.mycompany.app</groupId>
<artifactId>my-webapp</artifactId>
<packaging>war</packaging>
<version>1.0-SNAPSHOT</version>
<name>Maven Webapp Archetype</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<finalName>my-webapp</finalName>
</build>
</project>
java应用程序¶
mvn archetype:create -DgroupId=com.mycompany.ap -DartifactId=my-app
命令正确执行后,生成如下目录:
my-app
|-- pom.xml
`-- src
|-- main
| `-- java
| `-- com
| `-- mycompany
| `-- app
| `-- App.java
`-- test
`-- java
`-- com
`-- mycompany
`-- app
`-- AppTest.java
其pom.xml文件内容如下:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.mycompany.ap</groupId>
<artifactId>my-app</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>Maven Quick Start Archetype</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>
Maven项目的标准目录介绍¶
Maven提倡使用一个共同的标准目录结构,使开发人员能在熟悉了一个Maven工程后,对其他的Maven工程也能清晰了解。这样做也省去了很多设置的麻烦。
以下的文档介绍是Maven希望的目录结构,并且也是目录创建工程是采用的目录结构。Maven推荐大家尽可能的遵守这样的目录结构。
src/main/java - 应用程序/库源码
src/main/resources - 应用程序/库资源
src/main/filters - 资源的filter文件
src/main/assembly - assembly描述符
src/main/config - 配置文件
src/main/webapps - Web应用程序源码
src/test/java - 测试源码
src/test/resources - 测试资源
src/test/filters - 测试资源的filter
src/site - 站点
LICENSE.txt - 项目许可
README.txt - 项目readmine
在顶级目录上是工程的描述文件pom.xml(如果使用Ant则还包括其他属性文件,maven.xml或build.xml),另外还包括提供给最终用户的文件,如,README.txt, LICENSE.txt等等。
顶级目录还包括两个子目录:src,target。顶级目录下可能出现的其他目录仅仅是CVS或.svn和其他多模块工程的工程目录,最好不要再有其他目录。
Target目录是所有工程编译构建的输出目录。
Src目录包含所有工程的源码文件,配置文件,资源文件等等。它下面的子目录一般包含main(主要的工程源文件),test(测试文件),site(项目站点文件)。
项目构建的生命周期的介绍¶
Maven 2是围绕着构建生命周期概念设计的。这意味着,构建或者发布的过程已经被清晰的定义了。
当我们使用Maven构建工程时,我们只需要了解几个Maven定义好的命令即可,其他的工作则交给POM来完成。
以下给出Maven提供的构建生命周期列表:
validate 验证项目是否正确,所有必要信息是否可用。
generate-sources 生成编译所需的任意源码。
process-sources 处理源码,比如过滤一些数值。
generate-resources 生成包里所需包含的资源。
process-resources 处理资源,并拷贝到目标目录中,以便打包。
compile 编译项目源码
process-classes 对编译生成的文件进行后期处理。比如,对Java类的字节码进行修改。
generate-test-sources 生成编译所需的任意测试代码
process-test-sources 处理测试代码,比如过滤一些数值。
generate-test-resources 生成测试用资源
process-test-resources 处理资源,并拷贝到测试用的目标目录中。
test-compile 编译测试代码,放到测试目标目录
test 用合适的单元测试框架来运行测试。这些测试不应当要求代码被打包或部署。
package 把编译好的代码打包成可以发布的格式,例如JAR
pre-integration-test 执行集成测试之前必须完成的动作,比如,设置集成测试所需的环境。
integration-test 执行集成测试。如果需要,会事先把包部署到集成测试所需的运行环境中。
post-integration-test 执行集成测试之后必须完成的动作,比如运行环境的清理。
verify 检查包是否合法,是否满足特定的质量要求
install 把包安装在本地仓库中,以便作为本地其他项目的依赖。
deploy 在集成或发布环境中完成部署,并且把最终的包拷贝到远程仓库中,以便被其他开发人员和工程所共享。
因此,当我们构建一个项目时,只需要了解自己希望做什么,然后执行以上对应的生命周期即可。
例如,我们希望编译我们的工程。在命令行状态下进入到工程的pom.xml文件所在的目录中,使用命令:mvn compile;希望构建打包我们的工程,使用mvn package即可。
当然了,maven的构建生命周期也是可以扩展和自定义的,这里就先不做介绍了。
pom.xml介绍¶
pom.xml包含了一个项目的项目对象模型(POM)。项目对象模型(POM)是Maven工作的基本单元。请记住,这个是非常重要的,因为POM包含了工程的非常重要的信息块,并且基本上包含了和项目相关的任何要素。
让我们熟悉一下pom.xml包含的基本项:
- poject 这是pom.xml的顶级元素。
- modelVersion 这是元素指出了这个POM使用的是那个版本的对象模型。这个模型的版本自身么是经常改变的,但这种改变是为了使模型更加的稳定。
- groupId 这个元素指出创建这个工程的组织或团队的唯一标识,并且这个也是一个项目的关键标识,推荐使用这个组织或团队的完整域名。例如:org.apache.maven.plugins是为Maven plug-ins定义的groupId。
- artifactId 这个元素指出这个工程的主要制品的基本名称。一个工程的主要制品如果是jar文件,次要制品如果是源码包,则次要制品的名称的一部分也使用 artifactId。典型的制品名称使用这样的格 式:<artifactId>-<version>.<extension>(例如,myapp- 1.0.jar)。
- packaging 这个元素指出制品的类型(例如:JAR,WAR,EAR等等)。这个元素不仅仅指示出制品的类型,同时也指示出工程构建过程中的部分生命周期。Packaging的默认值是JAR。
- version 这个元素指出这个项目产生的制品的版本号,Maven在帮助开发人员管理版本号时走了很长的路,以后你将经常看到SNAPSHOT在一个版本中,这个表示一个工程仍然在开发状态。
- name 这个元素指出这个工程显示的名称。这个常用于Maven产生的文档中。
- url 这个员算指出在哪里能发现工程的站点。这个常用于Maven产生的文档中。
- desription 这个元素提供了这个工程基本的描述。这个也常用于Maven产生的文档中。
以上只是pom.xml中的一些基本项,完整的pom.xml的元素介绍请参考:
http://maven.apache.org/maven-model/maven.html
文档编制¶
文档创建:¶
对于如何创建和编制文档,maven有一个简单的示例命令:
mvn archetype:create -DgroupId=com.mycompany.app -DartifactId=my-app -DarchetypeGroupId=org.apache.maven.archetypes -DarchetypeArtifactId=maven-archetype-site
执行了以上命令后,我们将得到这样一个目录结构:
my-app
|-- pom.xml
`-- src
|-- site
|-- apt
| |-- format.apt
| `-- index.apt
|-- fml
| `-- faq.fml
|-- fr
| |-- apt
| | |-- format.apt
| | `-- index.apt
| |-- fml
| | `-- faq.fml
| `-- xdoc
| `-- xdoc.xml
|-- site.xml
|-- site_fr.xml
`-- xdoc
`-- xdoc.xml
你现在可以看到一个$basedir/src/site目录,以及它包含的一些站点描述文件(site.xml,site_fr_xml),和各种maven支持的文档格式相对应的目录和示例文档都已经产生。
以上的创建只是示例,我们自己创建时就没有命令行使用了,只能按照上面的目录结构创建我们需要的文档,并在文档中写入我们工程的信息。
让我们再来看看maven所支持的文档格式。
文档格式¶
Maven支持3种文档格式:
- Xdoc format 这个是一种简单快捷的,基于original Anakia format的文件格式。
- APT format “Almost Plain Text”,(接近普通文本格式),这是一种允许你采用接近普通文本格式的方式简单的写出类似于wiki格式的结构性文档。
如果你对此很感兴趣,请参考完整的APT format的书写规范
http://maven.apache.org/guides/mini/guide-apt-format.html
- FML formate 这个是一种FAQ结构形式的文档格式。
了 解了以上的文档格式,我们就可以按照以上文档格式的要求,选用我们喜欢的文档格式编写我们的文档。当编写完成后,我们需要生成所有文档。这里生成文 档,maven的处理是生成站点(site),也就是身成html页面,这样所有对此项目感兴趣的人员都可以通过访问此站点来了解所有的信息。生成站点的 命令是:
mvn site
文档国际化¶
当然,你可能早就想到文档国际化的问题,这里maven也早就处理了。在pom.xml中
<project>
...
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-site-plugin</artifactId>
<configuration>
<locales>en,fr</locales>
</configuration>
</plugin>
</plugins>
...
</project>
注意到<locales>en,fr</locales>了吗?这里就支持了英语(en)和法语 (fr)两种语言的文档。请注意以下生成的目录,由于英语是在第一个,属于默认语言,所以$basedir/src/site目录下并没有en的文件夹, 而有fr的文件夹,而且这个文件夹里包含了maven支持的文档格式相对应的目录和示例文档。
报告设置¶
Maven有多个报告能添加在你的文档站点中,来显示项目当前的状态,这些报告采用插件的形式可在项目中配置。
为了为你的文档站点增加这些报告,必须增加reporting部分在pom.xml中,下面这个为标准的项目信息报告插件在pom.xml中的配置。
<project>
...
<reporting>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-project-info-reports-plugin</artifactId>
</plugin>
</plugins>
</reporting>
...
Maven在执行mvn site命令时,除了产生开发人员编制的文档信息外,根据pom.xml中设置的报告,会同时生成这个项目信息的报告文档。并且这个是默认的生成项。
这个默认的生成项将根据项目的信息生成以下报告:
- 持续集成信息(Continuous Integration)
- 依赖性信息(Dependencies)
- 发布追踪信息(Issue Tracking)
- 邮件列表信息(Mailing Lists)
- 工程协议信息(Project License)
- 项目团队信息(Project Team)
- 源码库信息(Source Repository)
根据笔者测试,以上信息均是在pom.xml进行设置的。
- 持续集成信息根据以下配置信息生成:
<ciManagement>
<system/>
<url/>
<notifiers>
<notifier>
<type/>
<sendOnError/>
<sendOnFailure/>
<sendOnSuccess/>
<sendOnWarning/>
<address/>
<configuration/>
</notifier>
</notifiers>
</ciManagement>
依赖性信息根据以下配置信息有关
<dependencies>
<dependency>
<groupId/>
<artifactId/>
<version/>
<type/>
<classifier/>
<scope/>
<systemPath/>
<exclusions>
<exclusion>
<artifactId/>
<groupId/>
</exclusion>
</exclusions>
<optional/>
</dependency>
</dependencies>
issue追踪信息
<issueManagement>
<system/>
<url/>
</issueManagement>
邮件列表信息
<mailingLists>
<mailingList>
<name/>
<subscribe/>
<unsubscribe/>
<post/>
<archive/>
<otherArchives/>
</mailingList>
</mailingLists>
笔者在pom.xml中设置以上信息后,运行 mvn site 总会报错。如果哪位了解到报错原因请告诉我,谢谢。[email protected]
工程协议信息
<licenses>
<license>
<name/>
<url/>
<distribution/>
<comments/>
</license>
</licenses>
项目团队信息
<organization>
<name/>
<url/>
</organization>
<developers>
<developer>
<id/>
<name/>
<email/>
<url/>
<organization/>
<organizationUrl/>
<roles/>
<timezone/>
<properties/>
</developer>
</developers>
<contributors>
<contributor>
<name/>
<email/>
<url/>
<organization/>
<organizationUrl/>
<roles/>
<timezone/>
<properties/>
</contributor>
</contributors>
源码库信息
<scm>
<connection/>
<developerConnection/>
<tag/>
<url/>
</scm>
默认情况下这些文档将生成在$basedir/src/site目录下。
需要得到其他的报告,则需要配置其他的报告插件。
要想了解更多的信息,请参考以下网页:http://cvs.peopleware.be/training/maven/maven2/morePlugins.html
依赖管理¶
这里我们通过使用外部依赖(external dependencies)来大家对maven的依赖管理有一个简单而具体的了解。
当我们在做一个工程的时候,不可能一切都是从空白开始,对于我们做Web应用的来说,使用框架已经司空见惯,而这种对框架的引入使用对于Maven来说,就是工程的依赖。而我们的工程要进行测试,则不能少了对Junit框架的依赖。
依 赖管理是maven的一个主要特征,这个是对于用户来说,是Maven令人振奋的一个最著名的特征。对于一个单一的工程来说,依赖管理没有什么困难的,但 是当你开始处理多个模块的工程或由10多个甚至上百个模块组成的应用程序时, Maven能帮助你轻松稳定的控制这些大量的依赖。
在pom.xml中dependencies部分列出了所有外部依赖,详细描述了在编译时,测试时,运行时是否需要这个依赖。现在,假定我们的工程只有对Junit的依赖。它的pom.xml文件可能如下:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.mycompany.app</groupId>
<artifactId>my-app</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>Maven Quick Start Archetype</name>
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>
从以上pom.xml文件可以看出,定义一个外部依赖(external dependencies)至少需要4个元素:groupId, artifactId, version, and scope。对于groupId, artifactId, version的意思,和前面我们在创建工程时提到的这几个元素的意义相同,这里就不再重复介绍,scope元素指出你的工程如何使用依赖,并且它的值有 compile,test和runtime等等。想要了解更多的依赖说明的信息,请看:http://maven.apache.org/maven-model/maven.html
要想了解完整的依赖机制,请看:http://maven.apache.org/guides/introduction/introduction-to-dependency-management.html
有了这些依赖信息,Maven将能在工程构建时引用依赖。
引用的过程是:
- 在本地仓库(默认的本地仓库地址为:~/.m2/repository)中查找此依赖是否存在。
- 如果在本地仓库中未发现,则在远程仓库中下载此依赖,并下载到本地仓库中。
- 通过以上两个步骤就能找到依赖。如果远程仓库无法访问,则可以设置其他远程仓库。具体请看:http://maven.apache.org/guides/introduction/introduction-to-repositories.html
一个简单的例子。比如我们要添加一个log4j到我们的工程中。
首 先.需要了解log4j的groupId, artifactId, and version信息。可在google上搜索“site:www.ibiblio.org maven2 log4j”。这样在搜索结果里可以找到/maven2/log4j/log4j (or /pub/packages/maven2/log4j/log4j)这样的目录,在这个目录中有一个文件叫做maven-metadata.xml。这 个文件内容如下所示:
<metadata>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.1.3</version>
<versioning>
<versions>
<version>1.1.3</version>
<version>1.2.4</version>
<version>1.2.5</version>
<version>1.2.6</version>
<version>1.2.7</version>
<version>1.2.8</version>
<version>1.2.11</version>
<version>1.2.9</version>
<version>1.2.12</version>
</versions>
</versioning>
</metadata>
这样我们能找到groupId为log4j,artifactId为log4j,version当然要用最新的,选择1.2.12。scope我们设置为compile。
这样我们使用mvn compile 编译工程时,会看到mvn下载了log4j到我们的本地仓库。
配置管理¶
Maven的配置管理是作为一个单独的Maven子项目在做。叫做SCM。他是这样介绍的:
MavenSCM 支持Maven 2.x插件(例如,maven-release-plugin)和其他工具(例如,Continuum,这个是一个和maven 2.x结合很好的一个持续集成工具。),Maven SCM提供给他们一个公共的API去做配置管理的各种操作。当然了要执行配置管理操作,当然少不了配置工具了。Maven SCM给出了一个列表,说明Maven SCM现在所支持的配置管理工具。
完全支持的配置管理工具:
- CVS
- Subversion
- Perforce
- StarTeam
当你选中了上面的一个配置管理工具,你就可以利用Maven 2.x的插件或者集成管理工具进行配置管理了。
持续集成工具continuum¶
continuum是Maven的一个子项目。他是一个构建基于java的工程的持续集成服务器。他支持以下多种工程类型:
- Maven 1
- Maven 2
- Ant
- Shell scripts
continuum有以下特征
- 紧密整合Maven 2.x
- 紧密整合Maven SCM
- 更易用的基于网络的设置和界面
- 基于Quartz(Quartz-based)的时间计划表设置
- 添加新项目十分方便
- 邮件通知
- 其他IM通知:IRC, Jabber, MSN
- 责备机制(Blame Mechanism)
在以下连接处下载此软件:http://maven.apache.org/continuum/download.html
安装¶
解压缩continuum-1.0.2-bin.zip到你希望安装Continuum 1.0.2的所在目录。运行:
- bin/linux/run.sh 如果是UNIX平台
- bin/solaris/run.sh 如果是Solaris平台
- bin/win32/run.bat 如果是Windows平台
- bin/macosx/run.sh 如果是MacOS X平台.
- bin/plexus.sh 如果是其他平台
当服务器启动成功后,打开浏览器访问:http://localhost:8080/continuum/
注意:由于continuum判断一个工程是否构建成功,是使用一个命令行返回值。而windows平台的用户,这个返回值有问题。因此需要修改以下maven 2的bin/mvn.bat文件。这里可以直接从以下地址下载修改后的文件替换掉即可:http://maven.apache.org/continuum/scripts/mvn.bat
添加一个项目到continuum¶
要添加一个maven 2的项目到continuum,需要写入一个pom url或者导入一个pom.xml,当然导入的这个pom.xml文件中包含了continuum需要的各种信息。
我们来看看导入的pom.xml文件中具体需要包含哪些项:
配置管理信息(The SCM information)¶
<scm>
<connection/>
<developerConnection/>
<tag/>
<url/>
</scm>
开发者信息(The developers)¶
<ciManagement>
<system>continuum</system>
<notifiers>
<notifier>
...
</notifier>
</notifiers>
</ciManagement>
集成后所有的通知人信息(The notifiers)¶
<notifier>
<type>mail</type>
<configuration>
<address>[email protected]</address>
</configuration>
<notifier>
<notifier>
<type>irc</type>
<configuration>
<host>irc.codehaus.org</host>
<port>6667</port>
<channel>#maven</channel>
</configuration>
</notifier>
构建工程¶
- 按照定制的时间构建
- 点击本项目上的build按钮进行构建。
发布管理¶
配置¶
要发布(Releases)一个项目,需要在pom.xml和setting.xml中分别配置。在pom.xml中
<distributionManagement>
<repository>
<id>mycompany-repository</id>
<name>MyCompany Repository</name>
<url>scp://repository.mycompany.com/repository/maven2</url>
</repository>
</distributionManagement>
在setting.xml中
<settings>
...
<servers>
<server>
<id>mycompany-repository</id>
<username>jvanzyl</username>
<!-- Default value is ~/.ssh/id_dsa -->
<privateKey>/path/to/identity</privateKey> (default is ~/.ssh/id_dsa)
<passphrase>my_key_passphrase</passphrase>
</server>
</servers>
...
</settings>
通过以上的设置,项目将可以发布到远程仓库,远程服务器。
项目发布现在支持scp,ftp和scpexe等方式。
Setting.xml文件是一个maven的配置文件。它有下面的功能:
- 配置本地仓库
- 配置访问网络的代理服务器
- 安全和部署的设置。
- 为仓库设置景象
想要了解更多这个文件的信息可以参考一下以下文章:http://maven.apache.org/guides/mini/guide-configuring-maven.html
运行发布的命令¶
mvn deploy
Maven和eclipse工具的合作¶
当有了以上的工程目录,无论是webapp工程,还是app,我们都希望在集成开发环境中开发。Maven如何和IDE集成。现在我们就来进行讲解。
首先要让eclipse知道Maven 2的repository(仓库)的路径。因此要设置一个M2_REPO的变量为classpath。可以使用命令行的方式来设置:
mvn -Declipse.workspace=<path-to-eclipse-workspace> eclipse:add-maven-repo
还可以在eclipse中定义一个新的classpath变量通过在eclipse的菜单上选择Window> Preferences. 选择Java > Build Path > Classpath Variables page.
接下来,生成eclipse的工程文件。使用命令行
mvn eclipse:eclipse
这样通过在eclipse的菜单上选择File >Import >Existing Projects into Workspace,就可以将工程导入eclipse中。
通过以上2个步骤,我们就可以利用eclipse来进行开发工作了。
Eclipse插件mavenide¶
同时在eclipse中我们可以下载一个maven的插件,用来辅助eclipse进行maven工程的开发工作。这个插件名称叫做mavenide。
这个插件可使用以下更新站点:http://m2eclipse.codehaus.org/
并且非常方便的是,这里还提供了一个flash的演示来介绍如何安装此插件,这个flash演示的观看地址在:
http://m2eclipse.codehaus.org/Installing_Maven_2.0_plugin_for_Eclipse.html
要正常使用此插件请注意以下问题:
- eclipse使用3.1或以上版本。
- Mavenide的插件为0.0.5不要安装错误了。
通过笔者在安装好此插件的一些使用后,看到了此插件的以下一些特性。
- 可以方便的添加依赖。
- 在编辑完pom.xml文档后,会自动检查此文档的格式是否正确。
- 可以将mvn的一些命令通过扩展工具的方式在eclipse中轻松执行。
心得体会¶
扬长避短使用Maven 2¶
转载自 http://www.javaeye.com/topic/162217
架设私服¶
比如Spring 2.5.1,可能刚release,repo1.maven.org/maven2/不一定有。你可以install到你的私服去。
结合Ant¶
很多maven不灵活的地方,可以用ant来解决
定义meta-inf的信息¶
开发OSGI的Bundle,就必须定义meta-inf信息。也可以定义自己的格式。
不要使用maven2相关的ide插件¶
多使用命令行。比如,先 mvn eclipse,然后导入到eclipse工程。有更新,执行 mvn eclipse,再刷新工程就可以。
我非常反对过多的依赖IDE。单元测试比较难做,无法做到持续集成!
题外话:我个人强烈倾向于调式用mvn jetty:run,数据库用hsqldb,便于使用dbunit。毕竟,现在可以用spring,jpa/hibernate做到数据库无关性和应用服务器无关性。
依赖关系要设计好¶
即jar和jar之间的关系,package和package之间的关系。开发前,设计的时候就要规划好,不能什么都靠工具。工具不是万能的。
尤其是开发OSGI bundle的时候,依赖关系一定要先设计好,一定要保证单向依赖性!
实际上,我使用maven,中间也遇到了一些问题,总的说来,帮助还是非常大。尤其是,新来的开发人员搭建开发、测试环境、持续集成的时候,效果非常明显!
我也承认maven2是好的思路,但是实现得不好。最重要的是,在新的工具出现前,我们只能选择它。不过,可以结合IVY,ant,尽可能的扬长避短。
Maven中的中文编码问题¶
在Windows下,默认编码是GBK,所以需要在pom中增加属性:
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.encoding>UTF-8</maven.compiler.encoding>
第一个在filter拷贝文件时用,第二个在编译时用。第二个属性是在 http://maven.apache.org/plugins/maven-compiler-plugin/ 翻到的
Maven2主要配置文件¶
pom.xml和settings.xml。
POM是Maven的核心对象模型,对于项目,一般只需要pom.xml就行了。
settings.xml配置在Maven2中存在两种级别:
用户级,针对操作系统登录用户而言。一般在$home/.m2/,对于windows用户,就是目录:C:\Documents and Settings\用户名\.m2\settings.xml。
全局级:一般在%M2_HOME%/conf/settings.xml,M2_HOME是Maven2的根目录环境变量名。
maven2具体应用¶
1.下载maven2
http://maven.apache.org/download.html
2.设置二环境变量:解压,如解压在D:\mvntest,然后设置系统环境变量M2_HOME=D:\apache-maven-2.0.8 ,path变量里添加D:\apache-maven-2.0.8\bin,方便Maven在任何目录下运行。
3.mvn -h可以查看帮助
如执行mvn --version可以查看版本信息
mvn --version
可以显示类似这样的信息:
Maven version: 2.0.8
Java version: 1.6.0
OS name: "windows xp" version: "5.1" arch: "x86" Family: "windows"
4.创建一个新项目:
Maven2的运行命令是mvn,常用命令为:
创建Maven项目:mvn archetype:create
编译源代码:mvn compile
编译测试代码:mvn test-compile
运行测试:mvn test
产生site:mvn site
打包:mvn package
在本地Repository中安装jar:mvn install
清除产生的项目:mvn clean
清除产生的项目:mvn clean
例如:创建一个新项目:
mvn archetype:create -DgroupId=com.mycompany.app -DartifactId=my-app
Maven指南¶
http://www.sonatype.com/books/maven-book/reference_zh/public-book.html
另一个Maven2简明教程¶
安装和配置
把maven-2.0.4-bin.zip解压到D:maven-2.0.4。
下面就是配置环境变量了,这和1.0的版本是一样的。(1)MAVEN_HOME:D:maven-2.0.4 (2)在Path 中加入%MAVEN_HOME%bin¶
这样配置就OK了。然后,我建立了如下目录:E:appmavenApp,当然这些可以随便建立,呵呵。
下面说一些Maven1.x和Maven2.x的不同(一些摘自一些网友文章)
------------------------------------
Maven2 把配置文件压缩成了pom.xml和settings.xml 两个文件,简洁了不少。POM是Maven的核心对象模型,在Maven2中POM已由project.xml转移到pom.xml中使用,版本也由3升 级为4。对于项目,一般只需要pom.xml就行了。在Maven2中不需要也不提倡使用maven.xml
生命周期的引入
在Maven2中有了明确的生命周期概念,而且都提供与之对应的命令,使得项目构建更加清晰明了。主要的生命周期阶段:¶
validate,验证工程是否正确,所有需要的资源是否可用。
compile,编译项目的源代码。
test-compile,编译项目测试代码。
test,使用已编译的测试代码,测试已编译的源代码。
package,已发布的格式,如jar,将已编译的源代码打包。
integration-test,在集成测试可以运行的环境中处理和发布包。
verify,运行任何检查,验证包是否有效且达到质量标准。
install,把包安装在本地的repository中,可以被其他工程作为依赖来使用
deploy,在整合或者发布环境下执行,将最终版本的包拷贝到远程的repository,使得其他的开发者或者工程可以共享。
generate-sources,产生应用需要的任何额外的源代码,如xdoclet。
新增Dependency Scope
在POM 4中,<dependency>中还引入了<scope>,它主要管理依赖的部署。目前<scope>可以使用5个值:¶
compile,缺省值,适用于所有阶段,会随着项目一起发布。
provided,类似compile,期望JDK、容器或使用者会提供这个依赖。如servlet.jar。
runtime,只在运行时使用,如JDBC驱动,适用运行和测试阶段。
test,只在测试时使用,用于编译和运行测试代码。不会随项目发布。
system,类似provided,需要显式提供包含依赖的jar,Maven不会在Repository中查找它。
配置¶
下面说些基本设置,打开D:/maven-2.0.4/conf/settings.xml
1. 改变<localRepository>E:/app/m2/repository</localRepository> 目的:改变本地的数据仓库目录(存放从远程下载的jar包),如果不改变也可以,如不改变,缺省目录为:C:Documents and Settings主机名.m2repository
2. 配置代理,主要目的是为了能从远程下载jar包,根据实际的网路情况进行配置吧。因为我现在单位是有代理服务器的,如果不配置,就不能从远程下载jar包了。我的配置如下(注意:如果你的网络没有代理服务器,就不用配置这个步骤)
<proxy>
<id>optional</id>
<active>true</active>
<protocol>http</protocol>
<host>192.168.17.100</host>
<port>8889</port>
<nonProxyHosts>192.168.*.*</nonProxyHosts>
</proxy>
常用goal¶
下面就是一些goal命令了,这里和Maven1有不少不同,常用的命令有:
- 创建Maven的普通java项目:mvn archetype:create -DgroupId=com.codeline.commons -DartifactId=pjoName
- 创 建Maven的Web项目:mvn archetype:create -DgroupId=com.mycompany.app -DartifactId=my-webapp -DarchetypeArtifactId=maven-archetype-webapp
- 编译源代码:mvn compile (或者:mvn compiler:compile)
- 编译测试代码:mvn test-compile
- 运行测试:mvn test
- 产生site:mvn site
- 打包:mvn package
- 在本地Repository中安装jar:mvn install
- 清除产生的项目:mvn clean
- 生成eclipse项目:mvn eclipse:eclipse
- 生成idea项目:mvn idea:idea
- 组合使用goal命令,如只打包不测试:mvn -Dtest package
- 编译测试的内容:mvn test-compile
- 只打jar包: mvn jar:jar
- 只测试而不编译,也不测试编译:mvn test -skipping compile -skipping test-compile (这里要特别注意 -skipping 的灵活运用,当然也可以用于其他组合命令)
- 清除eclipse的一些系统设置:mvn eclipse:clean
配置存储库¶
要 求项目的每个开发者必须在conf目录中配置存储库是不方便的,所以Maven可以同时查看多个存储库并且将它们全部配置在pom.xml文件中。让我们 看看一个例子,它展示了如何在应用程序用使用多个存储库。在以下从pom.xml文件摘录的片断中,我们设置了两个存储库来让Maven寻找依赖项。 Ibiblio一直是默认的存储库,我们又添加了Planet Mirror作为后援存储库。我们也可以让团队使用的本地web服务器作为第二个存储库。
<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>
一些小问题¶
M2_REPO的问题¶
当 建立一个工程后,执行 mvn eclipse:eclipse ,建立一个maven的工程,用eclipse打开后,发现报如下错误:Unbound classpath variable: 'M2_REPO/junit/junit/3.8.1/junit-3.8.1.jar' in project my-webapp ,这是因为在Eclipse 没有配置 M2_REPO 变量,配置步骤:window >> preferences >> Java >> Build Path >> Classpath Variables
新建一个 M2_REPO 的变量,变量值指向你系统的Maven2的数据仓库位置。
POM.XML 继承的写法¶
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.apache.hivemind</groupId>
<artifactId>hivemind-examples</artifactId>
<packaging>jar</packaging>
<version>2.0-alpha-1</version>
<parent>
<groupId>org.apache.hivemind</groupId>
<artifactId>hivemind-project</artifactId>
<version>2.0-alpha-1</version>
<relativePath>../pom.xml</relativePath>
</parent>
<name>HiveMind Examples</name>
<inceptionYear>2003</inceptionYear>
<dependencies>
<dependency>
<groupId>org.apache.hivemind</groupId>
<artifactId>hivemind-framework</artifactId>
<version>2.0-alpha-1</version>
</dependency>
如何安装Jar(或war)依赖到本地的数据仓库中?¶
下面具一个如何把dwr.jar包上传到本地数据仓库的例子,一看例子,大家就明了了。
1. 下载dwr.jar包到本地,我把它放到了 C:/ (C盘根目录)
2. 进入“命令行提示符”,进入到C:/,然后执行
mvn install:install-file -Dfile=dwr.jar -DgroupId=dwr.mocha -DartifactId=dwrDart -Dversion=1.0 -Dpackaging=jar
这样就把dwr传到了本地仓库中(我的本地仓库地址为:E:appm2repository),上传到仓库中的jar包名为dwrDart- 1.0.jar,目录结构为dwr/mocha/dwrDart/1.0/dwrDart-1.0.jar
maven2命令大全¶
validate,验证工程是否正确,所有需要的资源是否可用。
compile,编译项目的源代码。
test-compile,编译项目测试代码。
test,使用已编译的测试代码,测试已编译的源代码。
package,已发布的格式,如jar,将已编译的源代码打包。
integration-test,在集成测试可以运行的环境中处理和发布包。
verify,运行任何检查,验证包是否有效且达到质量标准。
install,把包安装在本地的repository中,可以被其他工程作为依赖来使用
deploy,在整合或者发布环境下执行,将最终版本的包拷贝到远程的repository,使得其他的开发者或者工程可以共享。
generate-sources,产生应用需要的任何额外的源代码,如xdoclet。
结合Maven2进行J2EE项目构建¶
http://www.javaeye.com/topic/230265
Maven2 的新特性¶
http://www.ibm.com/developerworks/cn/opensource/os-maven2/index.html
maven 配置篇 之 settings.xml¶
http://zyl.javaeye.com/blog/41612
maven 配置篇 之pom.xml¶
配置1: http://zyl.javaeye.com/blog/41754
配置2: http://zyl.javaeye.com/blog/41761
新建文件
可选的描述
添加其它文件 (最大尺寸: 5 MB)