博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Maven使用小结
阅读量:2435 次
发布时间:2019-05-10

本文共 8117 字,大约阅读时间需要 27 分钟。

  (1)创建一个maven项目

  mvn archetype:create
  -DgroupId=org.sonatype.mavenbook.ch03
  -DartifactId=simple
  -DpackageName=org.sonatype.mavenbook

 

  相关解释说明

  mvn archetype:create  通过archetype插件快速创建一个项目
  -Dname=value  这样的对是将会被传到目标中的参数,java用来设置系统属性的方式
  artifactId          项目的基础目录(simple)
  simple项目下的pom.xml文件 描述了项目,配置了插件,声明了依赖
  src/main/java           java类文件
  src/main/resources  classpath资源文件
  src/test/java            测试java类文件
  src/test/resources    测试classpath资源文件

 

  (2)构建并打包项目(在包含pom.xml文件下运行)

  mvn install     
  运行后在target目录下生成simple-1.0-SNAPSHOT.jar文件(名称根据pom.xml文件配置得来),
  并安装到我们的本地maven仓库。

  (3)maven的pom.xml文件说明:

org.sonatype.maven.test
simple
1.0-SNAPSHOT
jar

    以上四个元素是maven的坐标,唯一标识了一个项目。

simple
http://maven.apache.org

   以上二个元素是pom提供的描述性元素,给人提供可阅读的名字。

junit
junit
3.8.1
test

   <dependencies>元素定义了项目的相关依赖,

  <scope>元素为test,说明只有在运行compiler:testCompile和surefire:test时才会被加到classpath中。
  <scope>元素如果为provided,则依赖在编译的时候需要,但是不应该被捆绑在构建的输出中。
                 在开发web应用时很有用。
  maven支持传递性依赖,会隐式地把相关依赖间接依赖的包也加到项目中。

 

(4)验证程序是否工作(java -cp 指定类运行所依赖其他类的路径,多个依赖包用;隔开)

      java -cp target/simple-1.0-SNAPSHOT.jar org.sonatype.maven.App

 

(5)-查看有效的(effective)pom,即maven真正运行根据的pom

      mvn help:effective-pom (在项目的基础目录下simple运行)

 

(6)maven项目打包

  mvn package 运行到打包为止的所有阶段,包含以下一系列插件目标
  mvn resources:resources
         compiler:compile
        resources:testResources
        compiler:testCompile
        surefire:test
        jar:jar
    
(7)浏览maven中央仓库  
        
  maven仓库的目录存储格式
      <groupId> / <artifactId> / <version> / <artifactId>-<version>.<packaging>

 

(8)生成站点文档和报告

       mvn site (生成文档目录在target/site目录下)

 

(9)查看相关依赖的groupId和artifactId

        (搜索依赖可查看pom.xml文件中的依赖元素)

 

(10)浏览项目的相关依赖(打印出已解决依赖的列表)

  1.mvn dependency:resolve(在项目目录下执行)
  2.mvn dependency:tree    (浏览项目的整个依赖树,包含间接依赖)

(11)执行单元测试
         mvn test      
  1.忽略单元测试失败,需要设置Surefire的testFailureIgnore的属性为true

org.apache.maven.plugins
maven-surefire-plugin
true

 2.跳过单元测试,需要设置Surefire的skip的属性为true

org.apache.maven.plugins
maven-surefire-plugin
true

 

(12)创建Maven的Web应用(需指定archetypeArtifactId为maven-archetype-webapp,打包成war)

       mvn archetype:create
       -DgroupId=org.sonatype.mavenbook.ch05
       -DartifactId=simple-webapp
       -DpackageName=org.sonatype.mavenbook
       -DarchetypeArtifactId=maven-archetype-webapp

  打包的War文件默认名称为<artifactId>-<version>.war

  如果定义了finalName,则包名为<finalName>.war.
  如:<finalName>simple-webapp</finalName>

 

(13)配置Maven Jetty插件

    1.在pom.xml文件中配置

simple-webapp
org.mortbay.jetty
maven-jetty-plugin

  2.启动Web项目(调用Jetty插件的run目标)

   mvn jetty:run
  启动完后就可以通过()访问。

 

(14)Pom相关

  1.asm包(字节码操作)依赖包如果版本不一致,则项目会出问题。

  2.所有的pom文件都从超级pom继承,超级pom存放于

  {M2_HOME}\lib\maven-2.2.1-uber.jar\org\apache\maven\project

  3.查看项目的有效POM,超级POM和项目POM的合并(打印出XML文档)

  mvn help:effective-pom

  4.版本号格式(例:1.3.5, 1.3-beta-01)

  <主版本>.<次版本>.<增量版本>-<限定版本>

  5.pom的属性引用(${})

  例:${project.groupId}-${project.artifactId}
  maven提供了三个隐式的变量
  1.env 例:${env.PATH},暴露了操作系统,访问系统的环境变量
  2.project 例:${project.groupId},暴露了POM,访问POM的信息。
  3.settings 例:${settings.offline},暴露了Maven Settings的信息,
  引用settings.xml文件中offline元素的值。

 

(15)项目依赖的依赖范围

  1.compile(编译范围),默认的范围,在所有的classpath中可用,同时也会被打包。
  2.provided(已提供范围),只有在容器提供该依赖后才可使用,在编译时可用,但不会被打包。(例:Servlet Api)
  3.runtime(运行时范围),只有在运行和测试系统时需要,编译时不需要。(例:JDBC驱动)
  4.test(测试范围),只有在测试编译和测试运行阶段可用,编译和运行时不需要。
  5.system(系统范围),与provided类似,必须显示的提供一个对于本地系统中JAR文件的路径。不推荐使用。

 

  6.使用依赖的多个版本

  (,) 不包含量词
  [,] 包含量词
  例:<version>[3.8,4.0]</version> 依赖于3.8-4.0之间的版本
  <version>[,3.8.1]</version> 依赖于<=3.8.1的版本

  7排除传递性依赖(配置exclusions元素)

log4j
log4j
1.2.16
javax.mail
mail
javax.jms
jms

 

  8.统一依赖版本号

    在子项目中引用依赖而不用显示的列出版本号(dependencyManagement元素),
  版本升级时不用手工的一个个修改依赖的pom.xml文件。

mysql
mysql-connector-java
5.1.2

  在子项目中引用依赖,不用指定版本号

mysql
mysql-connector-java

  如果子项目中指定了版本,将覆盖顶层POM的dependencyManagement元素的版本号。

 

  9.多模块项目管理

  将很多项目归类在一起,成为一个构建,打包类型总是POM.

sub-gooup-a
sub-gooup-b

 10.项目继承(当一个项目声明一个parent的时候,它从父项目的POM中继承信息)

com.training.killerapp
a-parent
1.0-SNAPSHOT

 

 (16).maven生命周期

  (1)清理生命周期(删除整个构建目录,target目录)
  mvn clean
  (2)默认生命周期阶段
  1.validate 验证项目是否正确
  2.generate-sources 生成所有需要包含在编译过程中的源代码
  3.process-sources 处理源代码,比如过滤一些值。
  4.generate-resources 生成所有需要包含在打包过程中的资源文件
  5.process-resources  复制并处理资源文件至目标目录,准备打包
  6.compile 编译项目的源代码
  7.process-classes 后处理编译生成的文件,例如对Java类进行字节码增强
  8.generate-test-sources 生成所有包含在测试编译过程中的测试源码
  9.process-test-sources 处理测试源码,比如过滤一些值
  10.generate-test-resources 生成测试需要的资源文件
  11.process-test-resources 复制并处理测试资源文件至测试目标目录
  12.test-compile 编译测试源码至目标目录
  13.test 使用合适的单元测试框架运行测试。这些测试应该不需要代码被打包或发布
  14.prepare-package 在真正的打包之前,执行一些准备打包必要的操作。
   这通常会产生一个包的展开的处理过的版本
  15.package 将编译好的代码打包成可分发的格式 ,如JAR,WAR,或者EAR
  16.pre-integration-test 执行一些在集成测试运行之前需要的动作。如建立集成测试需要的环境
  17.integration-test 如果有必要的话,处理包并发布至集成测试可以运行的环境
  18.post-integration-test 执行一些在集成测试运行之后需要的动作。如清理集成测试环境
  19.verify 执行所有检查,验证包是有效的,符合质量规范
  20.install 安装包至本地仓库,以备本地的其它项目作为依赖使用
  21.deploy 复制最终的包至远程仓库,共享给其它开发人员和项目(通常和一次正式的发布相关)

 

(17).过滤资源,替换属性

  默认的Maven行为会跳过过滤,只是将资源复制到输出目录。需显示地配置资源过滤

src/main/filters/default.properties
src/main/resources
true

 

 

(18).使用Maven Profile覆盖Compiler插件配置

production
true
org.apache.maven.plugins
maven-compiler-plugin
false
true

   1.profiles通常是pom.xml中最后一个元素

   2.每个profile必须要有一个id元素,通过传给Maven一个-P<profile_id>参数来调用profile.
   3.一个profile元素可以包含很多其它元素,只要这些元素可以出现在pom.xml文件的project元素下。
   4.mvn clean install -Pproduction -X (-X为开启调试输出)
    
(19).使用profile激活动态包含子模块

jdk16
1.6
simple-script

  1.如果在jdk1.6下运行,则会构建simple-script项目,否则不会构建。

  2.activation元素列出了所有激活profile需要的条件。
  其它方式:通过属性缺失激活(!表示否定,当没有设置${environment.type}属性时被激活.

!environment.type

 3.如果大量使用Maven Profile,可将profile从POM文件中分离,

  使用一个单独文件,名字为profiles.xml,放到项目目录下(同pom.xml),格式为

...

 4.setting profile可以应用到所有使用到Maven构建的项目,可以在两个地方定义

  (1).~/.m2/settings.xml(特定用户)
  (2).${M2_HOME}/conf/settings.xml(全局)

  5.列出活动的profile

  mvn help:active-profiles

 

 (20).创建私服

  下载nexus()
  解压后运行目录下\bin\jsw\windows-x86-32\Nexus.bat,
  访问(默认admin,admin123)
  1.配置maven settings

Nexus
central
Nexus Public Mirror
http://localhost:8081/nexus/content/groups/public

 

2.或者

artifactory
nexus
local nexus
http://localhost:8081/nexus/content/groups/public
default
nexus
local nexus
http://localhost:8081/nexus/content/groups/public
default
artifactory

 3. 或者在项目pom.xml中加入

nexus
local nexus
http://localhost:8081/nexus/content/groups/public
nexus
local nexus
http://localhost:8081/nexus/content/groups/public

  配置后maven会从本地的nexus安装查阅(可在Public Repositories和Maven Central仓库中查到)

   
 (21)部署第三方构件到nexus 
   在nexus项目管理中
   找到Repositories,这里选择其中一个,例如3rd party,
   可以在下面看到一个Artifact Upload选项卡。
   打开在GAV Definition中选择GAV Parameters,在接下来的Group中选输入组织名,
   Artifact项输入artifactId ,Packaging:这里选择jar,
   之后上传一个自定义的jar文件,
   点击Add Artifact,Upload Artifact(s),上传成功后,
   在上边的3rd party上单击右键——ReIndex,然后刷新下这个列表,
   就可以看到下边多了.index文件夹和我们刚才上传相关的文件夹。 

转载地址:http://luxmb.baihongyu.com/

你可能感兴趣的文章
网络上经典的DOS小命令(转)
查看>>
sqlserver中的一些技巧(转)
查看>>
简化Windows 2003域控制器密码(转)
查看>>
GSM无线网络的虚拟分层(转)
查看>>
不用重装 轻松解决Windows系统棘手问题(转)
查看>>
对移动通信网络优化工作的一些见解(转)
查看>>
正确网络配置建议 减少卡机死机的关键(转)
查看>>
智能手机Smartphone开发从零起步(五)(转)
查看>>
防止木马,教你找回被盗的QQ号码(转)
查看>>
SEO技巧中你可能没有注意的细节(转)
查看>>
微软开始二代Windows Live 不见Cloud OS踪影
查看>>
SQL Server 7.0 入门(四)(转)
查看>>
心得分享:防火墙程序使用的几点经验(转)
查看>>
创建ISAPI扩展(转)
查看>>
ORACLE 9I 重建 TEMP 表空间(转)
查看>>
Windows Server 2003 R2 Beta 2将公测(转)
查看>>
Pocket PC应用程序中使用SQL Server CE(转)
查看>>
完美解决不修改NTLDR-最后一次正确配置的问题(修正)(转)
查看>>
在双硬盘上安装独立32位和64位双系统(转)
查看>>
MYSQL列类型参考(转)
查看>>