【JavaEE进阶】关于Maven
目录
🌴什么是Maven
🌲为什么要学Maven
🎍创建一个Maven项目
🎄Maven核心功能
🚩项目构建
🚩依赖管理
🎋Maven Help插件
🍀Maven 仓库
🚩本地仓库
🚩中央仓库
🚩私服
🚩Maven设置国内源
🏀配置当前项目setting
🏀设置新项目的setting
🌴什么是Maven
官方对于Maven的描述:
ApacheMavenisasoftwareprojectmanagementandcomprehensiontool. Basedonthe concept of aproject object model (POM), Mavencanmanageaproject'sbuild,reporting and documentation fromacentral piece of information.
翻译过来就是:
Maven是一个项目管理工具。基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通 过一小段描述信息来管理项目的构建,报告和文档的项目管理工具软件。
大白话:Maven是一个项目管理工具,通过pom.xml文件的配置获取jar包,而不用手动去添加jar包
🌲为什么要学Maven
为了简单,⽅便,提⾼我们的开发效率,减少我们的开发Bug.
🎍创建一个Maven项目
IDEA本⾝已经集成了Maven,我们可以直接使⽤,⽆需安装
以 下截图的idea版本为: 2021.3.2,不同版本的idea界⾯展⽰会有所不同
点击Create,就创建好了⼀个Maven项⽬
🎄Maven核心功能
Maven提供的功能⾮常多,Maven在咱们课程中的体现主要是以下两个⽅⾯:
- 项目构建
- 管理依赖
🚩项目构建
Maven提供了标准的,跨平台(Linux,Windows,MacOS等)的⾃动化项⽬构建⽅式,当我们开发了⼀个项⽬之后,代码需要经过编译,测试,打包,发布等流程,每次代码的修改,都需要经过这些流程,如果代码反复调试修改,这个流程就需要反复进⾏,就显得特别⿇烦,⽽Maven给我们提供了⼀套简单的命令来完成项⽬的构建.
注意:maven是一个单独的软件,和idea没有任何关系,只不过是idea为了方便吧maven集成过来了。
以下是maven对应的一些命令
比如:打包操作-> 点击package,就可以完成项⽬的打包操作
打包就是把所有的class⽂件,全部放在⼀起,打成jar包或者war包
jar包和war包都是⼀种压缩⽂件
jar包就是把开发⼈员已经写好的⼀些代码进⾏打包.打好的jar包就可以引⼊到其他项⽬中,也可以直接使⽤这些jar包中的类和属性.另外也可以打成可执⾏war包,这样的包就可以通过java-war命令来执⾏war包可以理解为是⼀个web项⽬,⾥⾯是项⽬的所有东西,通常⽤于⽹站
🚩依赖管理
前⾯说到,Maven是⼀个项⽬管理⼯具,通过pom.xml⽂件的配置获取jar包,⽽不⽤⼿动去添加jar包获取的jar包,其实就是依赖.
pom.xml就是maven的配置⽂件,⽤以描述项⽬的各种信息(简单的说Maven是一个项目管理工具,通过pom.xml文件来导入依赖,依赖就是在进行程序开发的时候,需要用到的一些第三方的东西)
例如,在前面讲述的MySQL中,进行JDBC编程的时候,需要手动下载mysql-connector-java的包,并且添加到项目中。
如果使⽤Maven,我们只需要在pom.xml中引⼊mysql-connector-java的依赖就可以了
在pom⽂件 标签内,添加依赖坐标,创建的依赖存放于dependencies目录下
注意:对于pom文件的任意改动,都需要进行刷新操作
此时这个mysql的包就导进来了
依赖传递:
早期我们没有使⽤maven时,向项⽬中添加依赖的jar包,需要把所有的jar包都复制到项⽬⼯程下.⽐如A依赖B,B依赖C,那么A项⽬引⼊B的同时,也需要引⼊C,如果我们⼿动管理这个依赖,这个过程就会⽐较⿇烦,我们需要知道每个库都依赖哪些库,以及这些依赖之间的版本是如何关联的
⽐如我们要吃⽕锅,需要有锅,有调料,有⻝材,以及确认什么样的锅,什么样的⻝材.
⽐如去医院看病,需要带上以往的病历,检查结果,处⽅等,并且要确认带的资料是正确的,如果⽇期错了,或者患者错了,带少了,就需要回去重新拿
但使⽤maven的话,就可以避免管理所需依赖的关系。我们只需要在pom⽂件中,定义直接依赖就可以了,由于maven的依赖具有传递性,所以会⾃动把所依赖的其他jar包也⼀起导⼊
⽐如吃⽕锅,现在我们可以点⼀个海底捞外卖,直接就把所有⻝材都送过来了,包括什么锅,配什么菜.⽐如去医院看病,借助"互联⽹",实现了信息共享,只需要带上⾝份证,以往的病历和检查结果就都可以看到了
如上图,项⽬A通过Maven引⼊Jar A时,会⾃动引⼊Jar B 和Jar C.
Jar A 和项⽬B就是项⽬A的直接依赖.
Jar B, Jar C是间接依赖.
依赖排除:
上述决定依赖传递非常的好,但是也有不好的地上,在上图中,假设项目B和jar A没有任何关系,不是一个人开发的,那么对于项目B中jar C用到的版本可能是2.0,jar A中的jar C可能用的版本是1.0,那么对于项目A来说,我们所使用的jar C用的版本是1.0还是2.0(有可能两个版本冲突)。
就需要依赖排除,假设使用1.0
就需要把2.0排除掉,就有可能导致项目C报错(通过SpringBoot进行解决,后续讲述)。
如何排除?
在xml文件中,填写exclusions
也可以自动的填入,使用插件
🎋Maven Help插件
当项⽬⽐较复杂时,我们就会有Jar包冲突的问题,这时候就需要去解决依赖冲突.解决冲突之前,需要先找到冲突,我们可以使⽤Maven Help插件来观察包和包之间的依赖关系
理解插件:
天⽕+擎天柱=>会⻜的擎天柱.
天⽕在牺牲之前把⾃⼰变成了擎天柱的"⻜⾏插件".在擎天柱需要起⻜的时候就变成翅膀装在擎天柱 ⾝上.不需要起⻜的时候就卸下来放到擎天柱的集装箱⾥.
像IDEA这样的程序虽然功能强⼤,但是也⽆法⾯⾯俱到.对于⼀些特殊场景的功能,开发者就可以开 发⼀些"插件".如果需要这个插件,就单独安装
插件就是对程序的⼀些特定场景,做出⼀些特定的功能的扩展.
简单的理解为借助工具,提升自身的一些功能。
安装插件:File -> Settings ->Plugins -> 搜索Maven Help -> 找到对应插件, 点击Install 安装即可, 安装后需要重启下idea,才能⽣效
安装完之后会多一个Dependency Analyzer文件(依赖的分析)
排除protobuf:右击-> Exclude
此时在Text文件中,就自动的处理了(帮我们处理依赖)
刷新之后,此时protobuf依赖就没有了
注意:当依赖冲突的时候,Maven会采⽤最短路径优先的原则去选择依赖,上述项目A到jar C2.0版本的路径是3,项目A到jar C1.0版本的路径是2,这里肯定是1.0版本的路径最短,默认就选择1.0,如果不想使用1.0,我们自己排除掉即可。
🍀Maven 仓库
我们通过短短⼏⾏代码, 加入了这个依赖,这个依赖就来了,这个依赖从哪里来的??
这个代码,我们称之为"坐标",也就是唯⼀的.
在Maven中,根据groupId、artifactId、version的配置,来唯⼀识别⼀个jar包,缺⼀不可.
当我们在pom⽂件中配置完依赖之后,点击刷新,Maven会根据坐标的配置,去仓库⾥寻找Jar包,并把他 下载下来,添加到项⽬中.这个Jar包下载的地⽅就称为仓库.
仓库:⽤于存储资源,管理各种jar包
Maven仓库的本质就是⼀个⽬录(⽂件夹),这个⽬录被⽤来存储开发中所有依赖(jar包,插件等).
Maven仓库分为两⼤类:本地仓库和远程仓库.其中远程仓库⼜分为中央仓库,私服和其他公共库
🚩本地仓库
本地仓库:File -> settings -> 搜索maven
将该地址复制出来,去此电脑中搜索,这就是本地仓库
小结:
本地仓库:⾃⼰计算机上的⼀个⽬录(⽤来存储jar包)
当项⽬中引⼊对应依赖jar包后,⾸先会查找本地仓库中是否有对应的jar包
- 如果有,则在项⽬直接引⽤
- 如果没有,则去中央仓库中下载对应的jar包到本地仓库
🚩中央仓库
中央仓库:maven 软件中内置⼀个远程仓库地址,就是中央仓库,服务于整个互联⽹.由Maven团队维护,全球唯⼀.
仓库地址:https://repo1.maven.org/maven2/
还可以通过https://mvnrepository.com这个⽹站来查询并下载,刚上传的jar包,不会在这个网站及时更新,会有一定延迟,以上述网站为准
jar版本选择:优先级:看需求 <- 尽量避免有漏洞 <- 随大流(使用情况,尽量不使用最新版本)
假如选择了8.3.0,点击去:直接将dependency文件复制到xml文件中即可
上述操作就是把mysql从远程仓库拉到本地仓库,再从本地仓库加载到项目中。
🚩私服
私有服务器,也称为私服
私服:⼀般由公司团队搭建的私有仓库.
私服属于某个公司,或者某个部⻔,往往需要⼀定权限.
有了私服之后,Maven依赖下载的顺序⼜发⽣了变化
当Maven需要下载资源的时候
- 先从本地仓库获取,本地仓库存在,则直接返回
- 如果本地仓库没有,就从私服请求,私服存在该资源,就直接返回
- 如果私服上不存在该资源,则从中央仓库下载,中央仓库不存在,就报错了…
- 如果中央仓库中存在,就先缓存在私服上之后,再缓存到本地仓库⾥,再为Maven的下载请求提供服务
🚩Maven设置国内源
因为中央仓库在国外,所以下载起来会⽐较慢,所以咱们选择借助国内⼀些公开的远程仓库来下载资源接下来介绍,如何设置国内源
🏀配置当前项目setting
File-> Settings -> 搜索maven
复制该路径,在此电脑中去搜索,若是存放于C盘,可能是找不到这个文件的
此时就分为两种情况
1. 有setting文件,进行修改该文件部分
2.没有setting文件
找到setting文件,根据上述路径进行存放
修改本地仓库地址/镜像服务地址:若不想存放c盘,将m2文件复制到你所放入的目录文件中,也可将setting放入m2文件中,修改idea中的maven地址即可。
🏀设置新项目的setting
上述配置的内容,只对当前项⽬⽣效,为了让后续新建的项⽬也⽣效,需要重新设置⼀下新项⽬的 Settings
当前项⽬和新项⽬共⽤⼀个setttings⽂件即可,所以新项⽬的设置,只需要确认⼀下settings⽂件的路 径即可.