mevan 的常用命令和参数解释

简介

Maven是一个项目管理工具,它包含了一个项目对象模型 (Project Object Model),一组标准集合,一个项目生命周期(Project Lifecycle),一个依赖管理系统(Dependency Management System),和用来运行定义在生命周期阶段(phase)中插件(plugin)目标(goal)的逻辑。当你使用Maven的时候,你用一个明确定义的项目对象模型来描述你的项目,然后Maven可以应用横切的逻辑,这些逻辑来自一组共享的(或者自定义的)插件。
  Maven 有一个生命周期,当你运行 mvn install 的时候被调用。这条命令告诉 Maven 执行一系列的有序的步骤,直到到达你指定的生命周期。遍历生命周期旅途中的一个影响就是,Maven 运行了许多默认的插件目标,这些目标完成了像编译和创建一个 JAR 文件这样的工作。

后来遇到的错误
当文件pom文件第一行 错误
==org.apache.maven.plugin.war.WarMojo ==
解决方法
在这里插入图片描述

mevan常用命令

  mvn archetype:generate 创建Maven项目

mvn compile 编译源代码
  mvn deploy 发布项目
  mvn test-compile 编译测试源代码
  mvn test 运行应用程序中的单元测试
  mvn site 生成项目相关信息的网站
  mvn clean 清除项目目录中的生成结果
  mvn package 根据项目生成的jar
  mvn install 在本地Repository中安装jar
  mvn eclipse:eclipse 生成eclipse项目文件
  mvnjetty:run 启动jetty服务
  mvntomcat:run 启动tomcat服务
  mvn clean package -Dmaven.test.skip=true:清除以前的包后重新打包,跳过测试类

mevan工程结构

工程名-> src->main (放运行文件)->java(放java文件)
                                                    ->resources(放入外部资源文件)
                    -> test(放测试文件)

为啥遵守meavan的工程结构
mevan负责构建这个项目的自动化构建 他必须知道java源文件在哪里
我们自己自定义的东西明确要让mevan知道
用配置的方法明确告诉框架你
遵守框架内部的约定

  3.约定>配置>编码

依赖
依赖的传递性
好处可以传递的依赖不比在每个模块中都重复声明 在最下面的 工程添加一个依赖就行了
注意 非 compile范围的依赖不可以传递 所以在各个工程模块中需要一个个声明
依赖的排除(通常是自动导入的依赖jar 包 他不是稳定版本我们工程不想用它)

<exclusions>    //在根文件配制里面配制这个就可以在那个工程里面配制在那个工程里面生效 后面的工程自然也就没有了依赖
  <exclusion>
  <groupId>commons- logging</groupId>
  <artifactId>commons - loggingk/artifactId)
     </exclusion>
</exclus ions>

依赖的原则
1 就近者有限 传递的越近越优先
2通距离这 先声明的优先
统一管理依赖
1 手动配置
2使用properties 配置参数
在这里插入图片描述
读取参数
在这里插入图片描述
继承
①创建Parent工程,打包方式为pom
②收集所有非compile范围的依赖信息,使用dependencyManagement标签统一管理

<dependencyManagement>
            <dependencies>
                <dependency>
                    <groupId>junit</groupId>    //要要管理的jar包
                    <artifactId>junit</artifactId>
                    <version>4.9</version>
                    <scope>test</scope>
                </dependency>
            </dependencies>
        </dependencyManagement>

③在各个子工程中引用父工程

<parent>
            <groupId>com.atguigu.maven</groupId>
            <artifactId>Parent</artifactId>
            <version>0.0.1-SNAPSHOT</version>
            
            <!-- 以当前文件为基准查找父工程中pom.xml文件的相对路径 -->
            <relativePath>../Parent/pom.xml</relativePath>
        </parent>

④删除子工程中的重复信息
groupId
artifactid
⑤在子工程中找到被父工程管理的依赖信息,删除版本号部分
⑥在父工程中统一修改已管理的依赖信息的版好、版本号,看是否能够控制所有子工程

.聚合

在总的聚合工程中加入如下信息 这个聚合工程可以在父类

<modules>
        <module>../Hello</module>
        <module>../HelloFriend</module>
        <module>../MakeFriends</module>
    </modules>
在总的聚合工程中加入如下信息
<modules>
    <module>../Hello</module>
    <module>../HelloFriend</module>
    <module>../MakeFriends</module>
</modules>

尚硅谷教程

1.解压部署Maven核心程序
①检查JAVA_HOME环境变量
C:\Windows\System32>echo %JAVA_HOME%
D:\DevInstall\jdk1.7.0_07
②解压Maven的核心程序
将apache-maven-3.2.2-bin.zip解压到一个非中文无空格的目录下。例如:D:\DevInstall\apache-maven-3.2.2
③配置环境变量
M2_HOME D:\DevInstall\apache-maven-3.2.2
path D:\DevInstall\apache-maven-3.2.2\bin
④查看Maven版本信息验证安装是否正确
C:\Windows\System32>mvn -v
Apache Maven 3.2.2 (45f7c06d68e745d05611f7fd14efb6594181933e; 2014-06-17T21:51:42+08:00)
Maven home: D:\DevInstall\apache-maven-3.2.2\bin…
Java version: 1.7.0_07, vendor: Oracle Corporation
Java home: D:\DevInstall\jdk1.7.0_07\jre
Default locale: zh_CN, platform encoding: GBK
OS name: “windows 7”, version: “6.1”, arch: “amd64”, family: “windows”
2.修改本地仓库
①默认本地仓库位置:~.m2\repository
~表示当前用户的家目录,例如:C:\Users[你当前登录系统的用户名]
②指定本地仓库位置的配置信息文件:apache-maven-3.2.2\conf\settings.xml
③在根标签settings下添加如下内容:[本地仓库路径,也就是RepMaven.zip的解压目录]
3.第一个Maven工程
①目录结构
Hello
|—src
|—|---main
|—|---|—java
|—|---|—resources
|—|---test
|—|---|—java
|—|---|—resources
|—pom.xml

 ②POM文件内容
<?xml version="1.0" ?> 4.0.0
 <groupId>com.atguigu.maven</groupId>
 <artifactId>Hello</artifactId>
 <version>0.0.1-SNAPSHOT</version>

 <name>Hello</name>
  
 <dependencies>
      <dependency>
           <groupId>junit</groupId>
           <artifactId>junit</artifactId>
           <version>4.0</version>
           <scope>test</scope>
      </dependency>
 </dependencies>
③编写主程序代码 在src/main/java/com/atguigu/maven目录下新建文件Hello.java,内容如下 package com.atguigu.maven; public class Hello { public String sayHello(String name){ return "Hello "+name+"!"; } } ④编写测试代码 在/src/test/java/com/atguigu/maven目录下新建测试文件HelloTest.java package com.atguigu.maven; import org.junit.Test; import static junit.framework.Assert.*; public class HelloTest { @Test public void testHello(){ Hello hello = new Hello(); String results = hello.sayHello("litingwei"); assertEquals("Hello litingwei!",results); } } ⑤运行几个基本的Maven命令 mvn compile 编译 mvn clean 清理 mvn test 测试 mvn package 打包 ※注意:运行Maven命令时一定要进入pom.xml文件所在的目录! 4.第二个Maven工程 ①工程名:HelloFriend ②目录结构与第一个Maven工程相同 ③POM文件 <?xml version="1.0" ?> 4.0.0 com.atguigu.maven HelloFriend 0.0.1-SNAPSHOT HelloFriend
 <dependencies>
      <dependency>
           <groupId>junit</groupId>
           <artifactId>junit</artifactId>
           <version>4.0</version>
           <scope>test</scope>
      </dependency>         
     
      <dependency>
           <groupId>com.atguigu.maven</groupId>
           <artifactId>Hello</artifactId>
           <version>0.0.1-SNAPSHOT</version>
           <scope>compile</scope>
      </dependency>
     
 </dependencies>
④主程序:在src/main/java/com/atguigu/maven目录下新建文件HelloFriend.java package com.atguigu.maven; import com.atguigu.maven.Hello; public class HelloFriend { public String sayHelloToFriend(String name){ Hello hello = new Hello(); String str = hello.sayHello(name)+" I am "+this.getMyName(); System.out.println(str); return str; } public String getMyName(){ return "John"; } } ⑤测试程序:在/src/test/java/com/atguigu/maven目录下新建测试文件HelloFriendTest.java package com.atguigu.maven; import static junit.framework.Assert.assertEquals; import org.junit.Test; import com.atguigu.maven.Hello;
      public class HelloFriendTest {
           @Test
           public void testHelloFriend(){
                HelloFriend helloFriend = new HelloFriend();
                String results = helloFriend.sayHelloToFriend("litingwei");
                assertEquals("Hello litingwei! I am John",results);    
           }
      }
 ⑥运行Maven命令
      mvn install     安装

5.第三个Maven工程
①设置通过Maven创建的工程的JDK版本——一劳永逸
[1]打开settings.xml文件
[2]找到profiles标签
[3]加入如下配置

jdk-1.7

true
1.7


<maven.compiler.source>1.7</maven.compiler.source>
<maven.compiler.target>1.7</maven.compiler.target>
<maven.compiler.compilerVersion>1.7</maven.compiler.compilerVersion>


②工程坐标
groupId:com.atguigu.maven
ArtifactId:MakeFriends
Package:com.atguigu.maven
③在src/main/java中新建类com.atguigu.maven.MakeFriends
public String makeFriends(String name){
HelloFriend friend = new HelloFriend();
friend.sayHelloToFriend(“litingwei”);
String str = “Hey,”+friend.getMyName()+" make a friend please.";
System.out.println(str);
return str;
}
④在src/test/java中新建类com.atguigu.maven.MakeFriendsTest
package com.atguigu.maven;
import static junit.framework.Assert.assertEquals;
import org.junit.Test;
public class MakeFriendsTest {
@Test
public void testMakeFriends(){
MakeFriends makeFriend = new MakeFriends();
String str = makeFriend.makeFriends(“litingwei”);
assertEquals(“Hey,John make a friend please.”,str);
}
}
⑤添加依赖信息

junit
junit
4.9
test


com.atguigu.maven
HelloFriend
0.0.1-SNAPSHOT
jar
compile

⑥在Eclipse环境下执行Maven命令:右击pom.xml选择run as 中的命令执行即可
6.测试依赖的范围对传递性的影响
①在Hello中添加对spring-core的依赖

org.springframework
spring-core
4.0.0.RELEASE
compile

②在HelloFriend中查看spring-core是否被加入了运行时环境
③将Hello中对spring-core的依赖范围修改为test,再到HelloFriend中检查
④将Hello中对spring-core的依赖范围修改为provided,再到HelloFriend中检查
⑤结论:非compile范围的依赖不能传递,必须在有需要的工程中单独加入
7.测试依赖原则
①路径最短者优先
[1]在Hello中依赖log4j-1.2.17

log4j
log4j
1.2.17

      [2]在HelloFriend中依赖log4j-1.2.14
           <dependency>
                <groupId>log4j</groupId>
                <artifactId>log4j</artifactId>
                <version>1.2.14</version>
           </dependency>
      [3]查看MakeFriends中自动引入的log4j是哪个版本
     
 ②路径相同时先声明者优先
      [1]创建OurFriends工程,依赖log4j-1.2.17
      [2]让MakeFriends依赖OurFriends
      [3]测试MakeFriends中,HelloFriend和OurFriends依赖的先后顺序和引入的log4j版本之间的关系

8.创建Web工程
①ServletAPI依赖

javax.servlet
servlet-api
2.5
provided

②JSPAPI依赖

javax.servlet.jsp
jsp-api
2.1.3-b06
provided

9.Web工程自动部署

AtguiguWeb


org.codehaus.cargo
cargo-maven2-plugin
1.2.3


tomcat6x
D:\DevInstall\apache-tomcat-6.0.39


existing
D:\DevInstall\apache-tomcat-6.0.39


<cargo.servlet.port>8989</cargo.servlet.port>





cargo-run
install

run






10.继承
①创建Parent工程,打包方式为pom
②收集所有非compile范围的依赖信息,使用dependencyManagement标签统一管理



junit
junit
4.9
test



③在各个子工程中引用父工程

com.atguigu.maven
Parent
0.0.1-SNAPSHOT

           <!-- 以当前文件为基准查找父工程中pom.xml文件的相对路径 -->
           <relativePath>../Parent/pom.xml</relativePath>
      </parent>
 ④删除子工程中的重复信息
      groupId
      artifactid
 ⑤在子工程中找到被父工程管理的依赖信息,删除版本号部分
 ⑥在父工程中统一修改已管理的依赖信息的版本号,看是否能够控制所有子工程

11.聚合
在总的聚合工程中加入如下信息

…/Hello
…/HelloFriend
…/MakeFriends

おすすめ

転載: blog.csdn.net/weixin_43979902/article/details/120190840