1. Maven的生命周期怎么理解?
    1. 一个阶段是“构建生命周期”中的一个步骤。生命周期是指包含在一个项目构建中的一系列有序的阶段
    2. 插件目标可以附着在生命周期阶段上。随着Maven沿着生命周期的阶段移动,它会执行附着在特定阶段上的目标

2. 学习使用Help插件
    1. help:active-profiles
        列出当前构建中活动的Profile(项目的,用户的,全局的)。
    2. help:effective-pom
        显示当前构建的实际POM,包含活动的Profile。
    3. help:effective-settings
        打印出项目的实际settings, 包括从全局的settings和用户级别settings继承的配置。
    4. help:describe
        描述插件的属性。它不需要在项目目录下运行,但是你必须提供你想要描述插件的 groupId 和 artifactId。也可以传         入插件的前缀(如help)如: mvn help:describe -Dplugin=help -Ddetail(书上用-Dfull)

3. 运行mvn的方式

    1. mvn archetype:create 这里archetype是一个插件标识而create是目标标识,一个Maven插件是一个单个或者多          个目标的集合.该命令没有创建 src/main/resources目录
    2. create目标定义了一个配置属性archetypeArtifactId,不指定时它有一个默认值为maven-archetype-              

        quickstart,生成的目录名与artifactId匹配.指定 archetypeArtifactId 为 maven-archetype-webapp,将创建           一个web项目.
    3. mvn package 命令行并没有指定一个插件目标,而是指定了一个Maven生命周期阶段.生命周期是包含在一个项目        构建中的一系列有序的阶段

4. 插件

    1. Maven Surefire 插件是负责运行单元测试的插件.测试报告:target\surefire-reports
    2. Maven Archetype 插件
    3. Maven Exec 插件.它不是 Maven 核心插件,但它可以从Codehaus 的 Mojo 项目得到.虽然 Exec 插件很有用,         你不应该依赖它来运行你的应用程序.
       Exec 插件让我们能够在不往 classpath 载入适当的依赖的情况下,运行这个程序。Exec 能做这样的工作是因为            Maven 已经知道如何创建和管理你的 classpath 和你的依赖.
    4. Maven Dependency 插件.
        打印已解决依赖的列表: mvn dependency:resolve
        如果你想知道你项目的整个依赖树,你可以运行 dependency:tree 目标
    5. Maven Assembly 插件:是一个用来创建你应用程序特有分发包的插件.需要在 pom.xml 中的build 配置中添加               plugin 配置,再运行 mvn assembly:assembly 来构建这个装配

5. 项目坐标
    1. groupId, artifactId, version和packaging。这些组合的标识符拼成了一个项目的坐标.
    2. groupId以创建这个项目的组织名称的逆向域名(reverse domain name)开头
    3. version:正在开发中的项目可以用一个特殊的标识,这种标识给版本加上一个“SNAPSHOT”的标记
    4. packaging:也是Maven坐标的重要组成部分(不过在书上的后半部分又把它排除在坐标之外),但是它不是项目唯一         标识符的一个部分.你不能同时有一个拥有同样的groupId, artifactId和version标识的项目

6. 依赖范围

    1. 当一个依赖的范围是test的时候,说明它在Compiler插件运行compile目标的时候是不可用的。它只有在运行                 compiler:testCompile和surefire:test目标的时候才会被加入到classpath中.测试范围依赖是一个只在测试编译           和测试运行时在 classpath 中有效的依赖。如果你的项目是以 war 或者 ear 形式打包的,测试范围依赖就不会被           包含在项目的打包输出中。

7. 单元测试

    1. 忽略单元测试失败:1)设置 Surefire 的testFailureIgnore 这个配置属性为 true;2) mvn test -                                 Dmaven.test.failure.ignore=true

    2. 跳过单元测试:1)设置 Surefire 的skip这个配置属性为 true;2) mvn install -Dmaven.test.skip=true

8. web应用

    1. 可以通过mvn tomcat:run来启动web,并且不需要在pom.xml配置相应的插件.
        1. 跳过测试:-Dmaven.test.skip(=true)
        2. 指定端口:-Dmaven.tomcat.port=9090
        3. 忽略测试失败:-Dmaven.test.failure.ignore=true
    2. 也可以通过mvn jetty:run来实现相同的目的,不过需要在pom.xml中做相应的插件配置.

9.POM优化

   1. 优化依赖
      1. 依赖重复声明:找出所有被用于一个以上模块的依赖,然后将其向上移到父POM的dependencyManagement片             段,在这些依赖配置被上移之后,我们需要为每个POM移除这些依赖的版本,否则它们会覆盖定义在父项目中的                 dependencyManagement.父POM包含一个版本和一组排除配置,所有的子POM需要使用groupId和                       artifactId引用这个依赖。
      2. 版本重复问题:创建<properties>                                                                                  

          <hibernate.annotations.version>3.3.0.ga</hibernate.annotations.version></properties>属性

          ,然后在<dependency>配置节里加入<version>${hibernate.annotations.version}</version>
      3. 兄弟依赖不匹配:为兄弟项目使用内置的项目version和groupId
   2. 优化插件
       1. 使用元素顶层POM build元素下的pluginManagement元素
       2. 通过属性来解决插件里的依赖的版本重复问题.
   3. 使用Maven Dependency插件进行优化
       1. 总是为你代码引用的类显式声明依赖
       2. 运行dependency:analyze,该目标分析这个项目,查看是否有直接依赖,或者一些引用了但不是直接声明的依                赖。
       3. 为了进一步调查,运行dependency:tree目标,该目标会列出项目中所有的直接和传递性依赖。
   4. 大部分复杂的Maven多模块项目倾向于在顶层POM中定义所有的版本