至于为什么要写Maven这个系列呢?其实我自己还是感慨颇深的,在去年一年的工作中,接触了一帮出差过来支撑的兄弟,但是这帮兄弟也都是刚走出校门的,或者从其它行业转过来做开发的,经验都很少,基础的Maven都不会配置,更不要说Maven的那些概念了。其实,在我们周围很多的看似很厉害的“大牛”,他能和你侃侃而谈,从人工智能到大数据,从大数据到区块链等等,他们都能说出一二,但是一到落实的实处时,比如让他们“show me your code”的时候,他们总是很痛苦的,或者是漏洞百出的。所以,这个系列一来为需要补充Maven基础知识的兄弟提供一个捷径;二来总结一下自己Maven知识,以免像那些“大牛”一样。
首先我们需要知道的事情是Maven是依赖JDK的,所以不管是在Windows还是Linux,需要使用Maven,就必须要先安装JDK。每个版本Maven对JDK的版本要去都不一致,我们可以去Maven的官网下载页,可以看到Maven的安装要求。
对于Windows的安装来说,我们直接下载对应的安装包即可。关于Windows上安装Maven不是这篇文章的重点,我这里也就一笔带过,推荐网上的一篇教程吧。具体的安装步骤可以看这篇《 Maven在Windows上的安装与配置 》。
从Maven的官网下载安装包以后,进行解压。解压后得到 apache-maven-3.6.0
这个包;然后执行 ln -s apache-maven-3.6.0 maven
命令创建一个软链接,然后在系统环境变量PATH中添加以下环境变量:
export M2_HOME=~/maven export PATH=$PATH:$M2_HOME/bin
检查Maven是否安装成功,只需要输入 mvn -v
,如果输出如下图所示,就是安装成功了。
肯定就有小伙伴会问了,为什么要创建一个软链接。其实在Linux上安装软件包,我都有一个习惯,应该是我们整个公司也都是这样要求的。安装软件包时,会在安装目录旁平行的创建一个符号链接,以方便将来升级;以后Maven升级时,只需要下载新版本的Maven包,解压放在平行目录,然后修改这个链接就可以了。
M2_HOME
环境变量指向Maven的安装目录。我们可以看到Maven安装目录下有以下文件和文件夹:
conf
: settings.xml
。直接修改该文件,就能在机器上全局地定制Maven的行为。而一般情况下,我们都会复制该文件至 ~/.m2
目录下,然后修改该文件,在用户范围定制Maven的行为; bin
:该目录包含了 mvn
运行的脚本,这些脚本用来配置Java命令,配置好 classpath
和相关的Java系统属性,然后运行执行Java命令。该目录除了包含Unix和Windows平台运行的脚本外,还包含一个 m2.conf
文件,这是 classworlds
的配置文件,后续还会细说;
boot
:
该目录下只有一个 plexus-classworlds-2.5.2.jar
文件, plexus-classworlds
是一个类加载器框架,相对于默认的Java类加载器,它提供了个更丰富的语法以方便配置,Maven使用该框架加载自己的类库;
lib
:
该目录包含了所有Maven运行时需要的Java类库,Maven是分模块开发的,所以这里有多个Jar包。
NOTICE
:
记录了Maven包含的第三方软件;
LICENSE
:
记录了Maven使用的软件许可证;
README.txt
:
记录了Maven的简要介绍,包含安装需求及如何安装的简要命令等。
最佳实践一:设置 MAVEN_OPTS
环境变量
运行mvn命令实际上是执行了Java命令,既然是运行Java,那么运行Java命令可用的参数当然也应该在运行mvn命令时可用。
通常需要设置 MAVEN_OPTS
的值为 -Xms128m -Xmx512m
,因为Java默认的最大可用内存往往不能够满足Maven运行的需要。我们一般把 MAVEN_OPTS
设置成环境变量。
最佳实践二:配置用户范围 settings.xml
Maven用户可以选择配置 M2_HOME/conf/settings.xml
或者 ~/.m2/settings.xml
。前者是全局范围的,整个机器上的所有用户都会直接受到该配置的影响,而后者是用户范围的,只有当前用户才会受到该配置的影响。
我们在配置时,都是使用用户范围的 settings.xml
,主要是为了避免无意识的修改影响到系统中其它用户;如果有需求,需要统一系统中所有用户的 settings.xml
配置,这样就可以全局范围的 settings.xml
。
除了影响范围这个因素,配置用户范围 settings.xml
文件还便于Maven升级。直接修改conf目录下的 settings.xml
会导致Maven升级不便,每次升级到新版本的Maven,都需要复制 settings.xml
文件。如果使用 ~/.m2
目录下的 settings.xml
,就不会影响到Maven安装文件,升级时就不需要触动 settings.xml
文件。
这是一篇特别基础的Maven安装教程,对于Maven的入门有一定的帮助,希望大家能通过我的整个系列可以入门Maven,丰富自己的工具库。
果冻想,认真玩技术的地方。
2019年3月23日,于内蒙古呼和浩特。