$ mvn help:effective-pom
一旦你运行了此命令,你应该能看到一个大得多的POM,它暴露了Maven的默认设置
- 如果你运行mvn install命令,Maven会把我们项目的构件安装到本地仓库。
指定编译版本....<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.5</source>
<target>1.5</target>
</configuration>
</plugin>....
- 这是Maven最强大的特征之一,它支持了传递性依赖(transitive dependencies)。
- $ mvn siteMaven提供了很完整的可配置的报告,像Clover报告检查单元测试覆盖率,JXR报告生成HTML源代码相互间引用,这在代码审查的时候非常有用,PMD报告针对各种编码问题来分析源代码,JDepend报告分析源代码中各个包之间的依赖。通过在
pom.xml
中配置那些报告被包含在构建中,站点报告就可以被定制了。
- Exec 插件允许你运行 Java 类和其它脚本。 它不是 Maven 核心插件,但它可以从 Codehaus 的 Mojo 项目得到。想要查看 Exec 插件的完整描述,运行:
$ mvn help:describe -Dplugin=exec -Dfull
$ mvn install -Dmaven.test.skip=true
使用Maven Dependency插件进行优化
$ mvn dependency:analyze
$ mvn dependency:tree
- super pom,它是Maven安装的一部分,可以在
/usr/local/maven/lib
中的maven-2.0.9-uber.jar
文件中找到。如果你看一下这个JAR文件,你会看到在包org.apache.maven.project下看到一个名为pom-4.0.0.xml
的文件。
这个超级POM定义了一些由所有项目继承的标准配置变量。对这些变量的简单解释如下:
|
默认的超级POM定义了一个单独的远程Maven仓库,ID为central 。这是所有Maven客户端默认配置访问的中央Maven仓库。该配置可以通过一个自定义的settings.xml 文件来覆盖。注意这个默认的超级POM关闭了从中央Maven仓库下载snapshot构件的功能。如果你需要使用一个snapshot仓库,你就要在你的pom.xml 或者settings.xml 中自定义仓库设置。Settings和profile将会在Chapter 11, 构建Profile中和Section A.1, “简介”中的Appendix A, 附录: Settings细节小节中具体介绍。
|
|
中央Maven仓库同时也包含Maven插件。默认的插件仓库就是这个中央仓库。Snapshot被关闭了,而且更新策略被设置成了“从不”,这意味着Maven将永远不会自动更新一个插件,即使新版本的插件发布了。
|
|
build 元素设置Maven标准目录布局中那些目录的默认值。
|
|
从Maven 2.0.9开始,超级POM为核心插件提供了默认版本。这么做是为那些没有在它们POM中指定插件版本的用户提供一些稳定性。
|
版本号
一个Maven项目发布版本号用version
编码,用来分组和排序发布。Maven中的版本包含了以下部分:主版本,次版本,增量版本,和限定版本号。
变量
Maven提供了三个隐式的变量,可以用来访问环境变量,POM信息,和Maven Settings:
env
env
变量 暴露了你操作系统或者shell的环境变量。例如,在Maven POM中一个对/usr/lib/jvm/java-1.6.0-openjdk-1.6.0.0/bin:/usr/local/bin:/usr/local/maven/bin:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/java/latest/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin:/usr/bin:/usr/local/bin
的引用将会被/usr/local/bin:/usr/local/maven/bin:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/java/latest/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin:/usr/bin:/usr/local/bin
环境变量替换(或者Windows中的%PATH%
)。
project
project
变量暴露了POM。你可以使用点标记(.)的路径来引用POM元素的值。例如,在本节中我们使用过groupId
和artifactId
来设置构建配置中的finalName
元素。这个属性引用的语法是:org.sonatype.mavenbook-${project.
artifactId}
。
settings
settings
变量暴露了Maven settings信息。可以使用点标记(.)的路径来引用settings.xml
文件中元素的值。例如,${settings.offline}
会引用~/.m2/settings.xml
文件中offline
元素的值。
Note
你可能在老的构建中看到使用${pom.xxx}
或者仅仅${xxx}
来引用POM属性。这些方法已被弃用,我们只应该使用${project.xxx}
。
除了这三个隐式的变量,你还可以引用系统属性,以及任何在Maven POM中和构建profile中自定义的属性组。
Java系统属性
所有可以通过java.lang.System
中getProperties()
方法访问的属性都被暴露成POM属性。
依赖范围
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
compile(编译范围)
compile
是默认的范围;如果没有提供一个范围,那该依赖的范围就是编译范围。编译范围依赖在所有的classpath中可用,同时它们也会被打包。
provided(已提供范围)
provided
依赖只有在当JDK或者一个容器已提供该依赖之后才使用。例如,如果你开发了一个web应用,你可能在编译classpath中需要可用的Servlet API来编译一个servlet,但是你不会想要在打包好的WAR中包含这个ServletAPI;这个Servlet API JAR由你的应用服务器或者servlet容器提供。已提供范围的依赖在编译classpath(不是运行时)可用。它们不是传递性的,也不会被打包。
runtime(运行时范围)
runtime
依赖在运行和测试系统的时候需要,但在编译的时候不需要。比如,你可能在编译的时候只需要JDBC APIJAR,而只有在运行的时候才需要JDBC驱动实现。
test(测试范围)
test
范围依赖 在一般的 编译和运行时都不需要,它们只有在测试编译和测试运行阶段可用。测试范围依赖在之前的???中介绍过。
system(系统范围)
system
范围依赖与provided
类似,但是你必须显式的提供一个对于本地系统中JAR文件的路径。这么做是为了允许基于本地对象编译,而这些对象是系统类库的一部分。这样的构件应该是一直可用的,Maven也不会在仓库中去寻找它。如果你将一个依赖范围设置成系统范围,你必须同时提供一个systemPath
元素。注意该范围是不推荐使用的(你应该一直尽量去从公共或定制的Maven仓库中引用依赖)。
可选依赖
<dependency>
<groupId>swarmcache</groupId>
<artifactId>swarmcache</artifactId>
<version>1.0RC2</version>
<optional>true</optional>
</dependency>
依赖版本界限
Example 9.6. 指定一个依赖界限:JUnit <= 3.8.1
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>[,3.8.1]</version>
<scope>test</scope>
</dependency>
冲突解决
“排除一个传递性依赖”
<dependency>
<groupId>org.sonatype.mavenbook</groupId>
<artifactId>project-a</artifactId>
<version>1.0</version>
<exclusions>
<exclusion>
<groupId>org.sonatype.mavenbook</groupId>
<artifactId>project-b</artifactId>
</exclusion>
</exclusions>
</dependency>
多模块项目
文件系统上的目录结构也反映了该模块关系。Figure 9.3, “多模块项目关系”中的一组项目拥有如下的目录结构:
top-group/pom.xml
top-group/sub-group/pom.xml
top-group/sub-group/project-a/pom.xml
top-group/sub-group/project-b/pom.xml
top-group/project-c/pom.xml
分享到:
相关推荐
【Maven笔记1】—— Maven入门 Maven是一款强大的Java项目管理和构建工具,它解决了传统项目构建中的诸多痛点,使得Java开发变得更加规范和高效。在本文中,我们将深入探讨Maven的基本概念、功能以及如何解决上述...
1. 下载最新稳定版本的Maven,如Apache官方网站提供的`apache-maven-3.5.4`。 2. 解压缩文件至非中文、无空格的目录。 3. 配置环境变量,包括`Maven_HOME`指向安装路径,以及`Path`中添加`bin`目录,使系统能够识别`...
【尚硅谷Maven课程笔记代码资源】是一份全面学习Maven的资料集合,它涵盖了从基础到高级的各种知识点,旨在帮助开发者深入理解并熟练运用Maven进行自动化构建。该资源包含课件、源码和相关的笔记,使得学习过程更加...
maven学习笔记maven学习笔记maven学习笔记
1. **下载**:你可以从 Apache Maven 官方网站下载最新版本的 Maven 安装包。根据你的操作系统选择对应的版本,例如 Windows、Linux 或 macOS。 2. **安装**:解压缩下载的文件到你希望安装的目录,通常设置环境...
### 黑马Maven笔记详解 #### Maven简介与特点 Maven是一款强大的项目管理和构建工具,作为Apache基金会下的一个开源项目,它完全采用Java语言编写,主要用于管理Java项目。Maven通过标准化项目构建过程和依赖管理...
### 黑马Maven笔记第二天知识点总结 #### Maven的核心优势 **1. 统一管理JAR包** - **节省空间**:Maven通过中央仓库管理所有项目的依赖,避免了重复下载相同JAR包的问题,有效减少了硬盘空间的占用。 - **依赖...
### Maven核心知识点解析 #### Maven概述与价值 Maven是一个项目管理和综合工具,主要用于Java项目的构建、依赖管理和项目信息管理。通过Maven,开发者可以轻松地处理项目中的多个痛点问题,提升开发效率。 #####...
提供的配套视频( BV1kf4y147Q4 )可能涵盖了Maven的基础概念、POM的配置、依赖管理的实践、生命周期的执行流程,以及常见插件的使用方法。观看这个视频将有助于加深对Maven的理解,特别是对于初学者,通过视频形式...
1: 通过配置MAVEN_HOME 和 %% %MAVEN_HOME%\bin 然后进行mvn -version 测试 掌握 -Xms 与 -Xmx的相关配置 2: Maven目录分析: 2.1: bin: 含有mvn运行的脚本 2.2: boot:含有plexus-classworlds类加载器框架 ...
【标题】:“maven笔记:maven-overlay-实战笔记” 在 Maven 的世界里,"overlay" 是一个重要的概念,主要用于Web项目的构建和部署。Maven overlay 技术允许你将多个项目的输出“重叠”在一起,形成一个新的项目,...
1. **项目对象模型(POM)**:Maven项目的核心是POM,它包含了项目的基本信息、构建配置、依赖关系、插件配置等。POM.xml文件是这个模型的XML表示,定义了项目属性和构建指令。 2. **坐标(Coordinates)**:每个...
**Maven教程:基础篇——尚硅谷学习笔记 2022年** Maven是一个强大的Java项目管理和构建工具,由Apache软件基金会开发。它通过提供一个标准的项目对象模型(Project Object Model,POM)来简化项目的构建过程,并...
最新maven视频教程加源码笔记,内容完整有保证,是学习maven的不可多得的教程。
【标题】"maven笔记t-JavaWeb"主要聚焦于Java Web开发中Maven的使用,这是一套关于Maven的教程,旨在帮助开发者理解和掌握这个强大的构建工具。Maven是Apache软件基金会的一个项目,它简化了Java项目的构建、管理和...
《Maven开发者笔记》是一本面向Java开发者的实用指南,旨在帮助读者深入理解和掌握Maven这一强大的构建工具。Maven不仅简化了项目的构建过程,还提供了项目管理的标准化方法,使得依赖管理和构建流程变得规范而高效...