什么是 Maven
什么是
Maven
的正确发音是
[
ˈ
mev
ə
n]
,而不是“马瘟”以及其他什么瘟。
Maven
在美国是一个口语化的词
Maven
比较正式的定义是这么说的:
Maven
是一个项目管理工具,它包含了一个
项目对象模
(
POM
:
Project Object Model
)
,一组标准集合,一个项目生命周期
(Project Lifecycle)
,一个依赖管
(Dependency Management System)
,和用来运行定义在生命周期阶段
(phase)
中插件
(plugin)
目标
的逻辑。
能解决什么问题
、我们需要引用各种
jar
包,尤其是比较大的工程,引用的
jar
包往往有几十个乃至上百个, 每用
jar
包,都需要手动引入工程目录,而且经常遇到各种让人抓狂的
jar
包冲突,版本冲突。
、我们辛辛苦苦写好了
Java
文件,可是只懂
0
和
1
的白痴电脑却完全读不懂,需要将它编译成二
Eclipse
、
IDEA
等都可以将代
javac
命令一
、世界上没有不存在
bug
的代码,计算机喜欢
bug
就和人们总是喜欢美女帅哥一样。为了追求美为
bug
,因此写完了代码,我们还要写一些单元测试,然后一个个的运行来检验代码质量。
、再优雅的代码也是要出来卖的。我们后面还需要把代码与各种配置文件、资源整合到一起,定型
web
项目,还需要将之发布到服务器,供人蹂躏。
jar
Web
站
Maven 就可以解决上面所提到的这些问题。
的优势举例
Web
阶段项目,要能够将项目运行起来,就必须将该项目所依赖的一些
jar
包添加到
jar
CRM
项目的工程大小。
Web
项目构建的
CRM
项目如下:
WEB
程序要运行,我们必须将项目运行所需的
Jar
包复制到工程目录中,从
Maven
工程来构建,会发现总体上工程的大小会少很多。如下图
:
1.2 Maven 的两个精典作用
的依赖管理
的一个核心特性就是依赖管理。当我们涉及到多模块的项目(包含成百个模块或者子项目),管理依赖就变成
Maven
展示出了它对处理这种情形的高度控制。
WEB
项目中,我们必须将工程所依赖的
jar
包复制到工程中,导致了工程的变得很大。那么
工程是如何使得工程变得很少呢?
maven
工程中不直接将
jar
包导入到工程中,而是通过在
pom.xml
文件中添加所需
jar
jar
直接引入进来,在需要用到
jar
包的时候,只要查找
pom.xml
文
pom.xml
文件中的坐标,到一个专门用于
”
存放
jar
包的仓库
”(maven
仓库
)
中根据坐标从
jar
包,再把这些
jar
包拿去运行。
”
存放
jar
包的仓库
”
长什么样?
pom.xml
文件中的坐标,再到仓库中找到
jar
包,会不会很慢?从而导致这种方式
jar
包的仓库长什么样,这一点我们后期会分析仓库的分类,也会带大家去看我们
pom.xml
文件配置要引入的
jar
包的坐标,再读取坐标并到仓库中加载
jar
包,这
jar
包了,为了解决这个过程中速度慢的问题,
maven
中也有索引的概念,通
jar
包的速度,使得我们认为
jar
包基本跟放在本地的工程文件中再
maven
仓库中有了索引我
jar 包。
项目的一键构建
maven
进行管理,这个
maven
一个命令可以轻松完成整个工作。
Hello-Maven
工程的一键运行的过程。通过
tomcat:run
的这个命令,我们发现现在的
第2章 Maven 的使用
的安装
软件的下载
Maven
管理工具,我们首先要到官网去下载它的安装软件。通过百度搜索“Maven“如下:
Download
链接,就可以直接进入到
Maven
软件的下载页面:
apache-maven-3.5.3
版本,我们当时使用的是
apache-maven-3.5.2
版本,大家也可以下
下载地址:
http://archive.apache.org/dist/maven/maven-3/
软件的安装
下载后,将
Maven
解压到一个没有中文没有空格的路径下,比如
D:\software\maven
下面。
存放了
maven
的命令,比如我们前面用到的
mvn tomcat:run
存放了一些
maven
本身的引导程序,如类加载器等
存放了
maven
的一些配置文件,如
setting.xml
文件
存放了
maven
本身运行所需的一些
jar
包
maven
软件就可以使用了,前提是你的电脑上之前已经安装并配置好了
JDK
。
环境
:这里用的jdk1.8
及
JDK
配置
java
环境,安装
JDK1.7 +
版本
(将
JAVA_HOME/bin
配置环境变量
path
),我们使
JDK8
相关版本
MAVEN_HOME
,变量值就是你的
maven
安装 的路径(
bin
目录之前一级目录)
Maven
软件,注意这个目录就是之前你解压
maven
的压缩文件包在的的目录,最
输入命令验证是否按照成功
maven
的版本,及
jdk
的版本符合要求,这样我们的
maven
软件安装就成功了。
仓库
仓库的分类
的工作需要从仓库下载一些
jar
包,如下图所示,本地的项目
A
、项目
B
等都会通过
maven
jar
包并存在本地仓库,本地仓库 就是本地文
jar
包时则不再从远程仓库下载,因为本地仓库已经存在了,可以将本地仓库
jar
包,项目使用一些插件或
jar
包,
${user.dir}/.m2/repository
,
${user.dir}
表示
windows
用户目录。
jar
包,本地仓库没有,默认去远程仓库下载。
maven
软件中内置一个远程仓库地址
http://repo1.maven.org/maven2
,它是中
Maven
团队自己维护,里面存储了非常全的
jar
包,它包
本地仓库的配置
repository.rar
”解压至自己的
D:\repository
目录下(可以放在没有中文及空格的目录下)。
MAVE_HOME/conf/settings.xml
文件中配置本地仓库位置(
maven
的安装目录下):
打开 settings.xml文件,配置如下:
<localRepository>E:\repository</localRepository>
全局
setting
与用户
setting
仓库地址、私服等配置信息需要在
setting.xml
文件中配置,分为全局配置和用户配置。
maven
安装目录下的有
conf/setting.xml
文件,此
setting.xml
文件用于
maven
的所有
project
maven
的全局配置。
setting.xml
文件默认的位置在:
${user.dir}
目录中
,${user.dir}
指
windows
中的用户目录。
会先找用户配置,如果找到则以用户配置文件为准,否则使用全局配置文件。
2.3.1 Maven 工程的目录结构
maven
工程,它的
src
目录和
pom.xml
是必备的。
—— 存放项目的
.java
文件
—— 存放项目资源文件,如
spring, hibernate
配置文件
—— 存放所有单元测试
.java
文件,如
JUnit
测试类
—— 测试资源文件
—— 项目输出位置,编译后的
class
文件会输出到此目录
——
maven
项目核心配置文件
java
项目,那么就没有
webapp
目录
工程的运行
maven
工程目录(当前目录有
pom.xml
文件),运行
tomcat:run
命令。
http://localhost:8080/maven-helloworld/
问题处理
工程运行先从本地仓库找
jar
包,本地仓库没有再从中央仓库找,上边提示
downloading…
jar
,由于本地没有联网,报错。
maven
安装目录的
conf/setting.xml
文件中配置本地仓库,参考:“
maven
仓库
/
配置本地仓库章节”。
cmd
中通过一系列的
maven
命令来对我们的
maven-helloworld
工程进行编译、测试、运
是
maven
工程的编译命令,作用是将
src/main/java
下的文件编译为
class
文件输出到
target
进入命令状态,执行
mvn compile
,如下图提示成功:
查看 target 目录,class 文件已生成,编译完成。
是
maven
工程的测试命令
mvn test
,会执行
src/test/java
下的单元测试类。
执行
mvn test
执行
src/test/java
下单元测试类,下图为测试结果,运行
1
个测试用例,全部成功。
是
maven
工程的清理命令,执行
clean
会删除
target
目录及内容。
是
maven
工程的打包命令,对于
java
工程执行
package
打成
jar
包,对于
web
工程打成
war
是
maven
工程的安装命令,执行
install
将
maven
打成
jar
包或
war
包发布到本地仓库。
指令的生命周期
对项目构建过程分为三套相互独立的生命周期,请注意这里说的是“三套”,而且“相互独立”,
在进行真正的构建之前进行一些清理工作。
构建的核心部分,编译,测试,打包,部署等等。
包含了一个项目对象模型
(Project Object Model)
,一组标准集合,一个项目生命周期
(Project
,一个依赖管理系统
(Dependency Management System)
,和用来运行定义在生命周期阶段
中插件(plugin)目标(goal)的逻辑
(Project Object Model)
maven
工程都有一个
pom.xml
文件,通过
pom.xml
文件定义项目的坐标、项目依赖、项目信息、
(Dependency Management System)
maven
的依赖管理对项目所依赖的
jar
包进行统一管理。
junit4.9
,通过在
pom.xml
中定义
junit4.9
的依赖即使用
junit4.9
,如下所示是
junit4.9
(Project Lifecycle)
maven
完成项目的构建,项目构建包括:清理、编译、测试、部署等过程,
maven
将这些
通过执行一些简单命令即可实现上边生命周期的各各过程,比如执行
mvn compile
执行编译、
mvn clean
执行清理。
将整个项目管理过程定义一组标准,比如:通过
maven
构建工程有标准的目录结构,有
(plugin)
目标
(goal)
管理项目生命周期过程都是基于插件完成的。
开发
maven
项目
的
maven
配置
打开
File
Settings
配置
maven
maven
安装目录,指定
maven
安装目录下 conf 文件夹中 settings 配置文件。
中创建一个
maven
的
web
工程
idea
提供好的
maven
的
web
工程模板
创建完成后,手动补齐以下文件
或者
创建web
创建成功后.默认打开 pop.xml文件
src.main.java和src.main.test需要手动补齐
或者
点击 Next 填写项目信息
点击 Next,此处不做改动。
点击 Next 选择项目所在目录 点击 Finish 后开始创建工程,耐心等待,直到出现如下界面。
手动添加 src/main/java 目录,如下图右键 main 文件夹NewDirectory
创建一个新的文件夹命名为 java
点击 OK 后,在新的文件夹 java 上右键Make Directory asSources Root
创建一个
Servlet
创建了一个 Servlet,但报错
servlet-api-xxx.jar
包放进来,作为
maven
工程应当添加
servlet
的坐标,从而
jar
3.2.2.2 在 pom.xml 文件添加坐标
直接打开 hello_maven 工程的 pom.xml 文件,再添加坐标
jar
包的坐标时,还可以指定这个
jar
包将来的作用范围。
maven
工程都需要定义本工程的坐标,坐标是
maven
对
jar
包的身份定义,比如:入门程序的
项目名称,定义为组织名
+
项目名,类似包名
–>
模块名称
–>
当前项目版本号,
snapshot
为快照版本即非正式版本,
release
为正式发布版本
–>
:打包类型
:执行
package
会打成
jar
包
:执行
package
会打成
war
包
:用于
maven
工程的继承,通常父工程设置为
pom
坐标的来源方式
jar
包的坐标,但是很多情况我们是不知道
jar
包的的坐标,可以通过如下方
从互联网搜索
依赖范围
依赖
B
,需要在
A
的
pom.xml
文件中添加
B
的坐标,添加坐标时需要指定依赖范围,依赖范围包
:编译范围,指
A
在编译时依赖
B
,此范围为默认依赖范围。编译范围的依赖会用在
:
provided
依赖只有在当
JDK
或者一个容器已提供该依赖之后才使用,
provided
依
servlet api
被
tomcat
容器提供。
:
runtime
依赖在运行和测试系统的时候需要,但在编译的时候不需要。比如:
jdbc
runtime
范围的依赖会被打包。
:
test
范围依赖 在编译和运行时都不需要,它们只有在测试编译和测试运行阶段可用,
junit
。由于运行时不需要所以
test
范围依赖不会被打包。
:
system
范围依赖与
provided
类似,但是你必须显式的提供一个对于本地系统中
JAR
systemPath
磁盘路径,system依赖不推荐使用。
maven-web
工程中测试各各
scop
。
jar
包
——- compile
【默认范围 可以不写】(编译、测试、运行 都有效 )
、
jsp-api ——- provided
(编译、测试 有效,
tomcat
下
jar
冲突)
驱动
jar
包
—- runtime
(测试、运行 有效 )
(测试有效)
compile>provided>runtime>test
设置
jdk
编译版本
jdk1.8
,需要设置编译版本为
1.8
,这里需要使用
maven
的插件来设置:
pom.xml
中加入:
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
<encoding>UTF-8</encoding>
</configuration>
</plugin>
</plugins>
</build>
编写
servlet
src/main/java
中创建
ServletTest
内容如下
3.2.7 编写 jsp
3.2.8 在 web.xml 中配置 servlet 访问路径
添加
tomcat7
插件
idea
最右侧
Maven Projects
,
tomcat7
插件
tomcat7
插件下
tomcat7:run
命令直接运行项目
也可以直接点击如图按钮,手动输入 tomc7:run 命令运行项目
点击后弹出如下图窗口 3.2.10运行结果
新版本如下:
运行结果:
4
章
maven
工程运行调试
端口占用处理
tomcat:run
命令重启工程,重启之前需手动停止
tomcat
,否则报下边的错误:
断点调试
在弹出框中点击如图加号按钮找到 maven 选项
在弹出窗口中填写如下信息
完成后先 Apply 再 OK 结束配置后,可以在主界面找到我们刚才配置的操作名称。
如上图红框选中的两个按钮,左侧是正常启动,右侧是 debug 启动
5
章 总结
仓库
、
maven
仓库的类型有哪些?
、
maven
工程查找仓库的流程是什么?
、本地仓库如何配置?
常用的
maven
命令
maven
命令包括:
:编译
:清理
:测试
:打包
:安装
坐标定义
pom.xml
中定义坐标,内容包括:
groupId
、
artifactId
、
version
,详细内容如下:
项目名称,定义为组织名
+
项目名,类似包名
–>
模块名称
–>
当前项目版本号,
snapshot
为快照版本即非正式版本,
release
为正式发布版本
–>
:打包类型
:执行
package
会打成
jar
包
:执行
package
会打成
war
包
:用于
maven
工程的继承,通常父工程设置为
pom
基本配置
是
Maven
项目的核心配置文件,位于每个工程的根目录,基本配置如下:
:文件的根节点
.
:
pom.xml
使用的对象模型版本
:项目名称,一般写项目的域名
:模块名称,子项目名或模块名称
:产品的版本号
.
:打包类型,一般有
jar
、
war
、
pom
等
:项目的显示名,常用于
Maven
生成的文档。
:项目描述,常用于
Maven
生成的文档
:项目依赖构件配置,配置项目依赖构件的坐标
:项目构建配置,配置编译、运行插件等。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/81960.html