Maven是属于apache软件基金会下一个开源免费的项目,是跨平台的项目管理工具, Maven采用了一种被称之为Project Object Model (POM)概念来管理项目,所有的项目配置信息都被定义在一个叫做POM.xml的文件中。主要服务于基于Java平台的项目构建,依赖管理和项目信息管理,可以在代码进行部署的过程中自动解决项目中代码的依赖环境,需要从maven的镜像仓库中进行下载依赖环境,通常下载比较慢,企业中会在公司内部搭建nexus(私服),将构建项目中的依赖环境保存到nexus服务器中,提高访问速度。
POM项目对象模型,是Maven工程的基本工作单元,是一个XML文件,包含了项目的基本信息,用于描述项目如何构建,声明项目依赖等等。 执行任务或目标时,Maven会在当前目录中查找POM。读取POM,获取所需的配置信息,然后执行目标。 POM中可以指定以下配置:项目依赖、插件、执行目标、项目构建profile、项目版本、项目开发列表、相关邮件列表信息。
Maven的功能:
.
maven使用场景(从运维人员的角度来看):
项目构建过程包括:清理项目→编译项目→测试项目→生成测试报告→打包项目→部署项目这几个步骤,这六个步骤就是一个项目的完整构建过程。 Maven仓库 在Maven的专业术语中,仓库是指一个位置,Maven仓库是项目中依赖的第三方库,这个库所在的位置叫做仓库。在Maven中,任何一个依赖、插件或者项目构建的输出,都可以称之为构件。
Maven仓库能帮助我们管理构件(主要是Jar),它就是放置所有JAR文件(WAR、ZIP、POM等等)的地方。
Maven仓库有三种类型:本地、中央、远程。 本地仓库 Maven 的本地仓库,在安装 Maven 后并不会创建,它是在第一次执行 maven 命令的时候才被创建。
运行 Maven 的时候,Maven 所需要的任何构件都是直接从本地仓库获取的。如果本地仓库没有,它会首先尝试从远程仓库下载构件至本地仓库,然后再使用本地仓库的构件。
默认情况下,不管Linux还是 Windows,每个用户在自己的用户目录下都有一个路径名为 .m2/respository/ 的仓库目录。 中央仓库 Maven中央仓库是由Maven社区提供的仓库,其中包含了大量常用的库。 Maven内置了远程公用仓库 中央仓库包含了绝大多数流行的开源Java构件,以及源码、作者信息、SCM、信息、许可证信息等。一般来说,简单的Java项目依赖的构件都可以在这里下载到。
中央仓库的核心概念: 1、这个仓库由 Maven 社区管理; 2、不需要配置即可使用; 3、需要通过网络才能访问。
远程仓库(第三方仓库) 第三方仓库又称为内部中心仓库,也称为私服。 私服:一般是由公司自己设立的,只为公司内部共享使用。它既可以作为公司内部构件协作和存档,也可以作为公用类库镜像缓存,减少在外部访问和下载的频率(使用了私服就减少了对中央仓库的访问)。 了解更多可参考Maven教程
安装Maven,需要依赖jdk1.8版本 所需软件包(提取码:u27c)可以下载我提供的,也可根据需求来自行下载
1、配置jdk环境
#检测当前jdk,并卸载掉
[root@maven ~]# rpm -qa | grep jdk
copy-jdk-configs-1.2-1.el7.noarch
java-1.8.0-openjdk-headless-1.8.0.102-4.b14.el7.x86_64
java-1.8.0-openjdk-1.8.0.102-4.b14.el7.x86_64
java-1.7.0-openjdk-1.7.0.111-2.6.7.8.el7.x86_64
java-1.7.0-openjdk-headless-1.7.0.111-2.6.7.8.el7.x86_64
[root@maven ~]# rpm -e java-1.8.0-openjdk-headless-1.8.0.102-4.b14.el7.x86_64 --nodeps
[root@maven ~]# rpm -e java-1.7.0-openjdk-headless-1.7.0.111-2.6.7.8.el7.x86_64 --nodeps
#解压jdk包
[root@maven ~]# tar zxf jdk-8u211-linux-x64.tar.gz -C /usr/local/
[root@maven ~]# vim /etc/profile
....
export JAVA_HOME=/usr/local/jdk1.8.0_211
export JRE_HOME=/usr/local/jdk1.8.0_211/jre
export CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar
export PATH=$JAVA_HOME/bin:$JRE_HOME/bin:$PATH
[root@maven ~]# source /etc/profile # 执行文件刷新变量
[root@maven ~]# java -version # 查看当前版本
java version "1.8.0_211"
Java(TM) SE Runtime Environment (build 1.8.0_211-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.211-b12, mixed mode)
2、部署Maven
[root@maven ~]# wget https://archive.apache.org/dist/maven/maven-3/3.6.1/binaries/apache-maven-3.6.1-bin.tar.gz
[root@maven ~]# tar zxf apache-maven-3.6.1-bin.tar.gz
[root@maven ~]# mv apache-maven-3.6.1/ /usr/local/maven
[root@maven ~]# vim /etc/profile
export MAVEN_HOME=/usr/local/maven
export PATH=$PATH:$MAVEN_HOME/bin
[root@maven ~]# source /etc/profile # 执行脚本使配置生效
[root@maven ~]# mvn -v # 执行命令出现如下版本信息表示安装成功
Apache Maven 3.6.1 (d66c9c0b3152b2e69ee9bac180bb8fcc8e6af555; 2019-04-05T03:00:29+08:00)
Maven home: /usr/local/maven
Java version: 1.8.0_211, vendor: Oracle Corporation, runtime: /usr/local/jdk1.8.0_211/jre
Default locale: en_US, platform encoding: UTF-8
OS name: "linux", version: "3.10.0-514.el7.x86_64", arch: "amd64", family: "unix"
1)构建项目进行测试
[root@maven ~]# mkdir /tmp/testdir
[root@maven ~]# cd /tmp/testdir/
#执行下面命令进行测试
[root@maven testdir]# mvn archetype:generate -DgroupId=com.zyz.maven.quickstart -DartifactIdk=testapp -DarchetypeArtifactId=maven-archetype-quickstart
#忽略一些信息,到如下行时输入执行命令时指定的项目名称,接下来的直接按回车保持默认即可
Define value for property 'artifactId': testapp
#当出现如下信息是,表示安装成功,尤其是第一行success
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 21:50 min
[INFO] Finished at: 2020-05-02T13:27:26+08:00
[INFO] ------------------------------------------------------------------------
#创建一个maven项目(Java类型),有交互就回车确认,可加-DinteractiveMode=false取消交互过程
#上述命令解释如下:
# archetype:generate:创建一个简单的java项目;
# archetype 也就是原型,是一个 Maven 插件,准确说是一个项目模板,它的任务是根据模板创建一个项目结构。
#使用 quickstart 原型插件创建一个简单的 java 应用程序
# -DgroupId:组织名,公司网址的反写(反向域名)+项目名称;
# -DartifactIdk:项目名或者模块名;
# - DarchetypeArtifactId:指定 ArchetypeId,maven-archetype-quickstart,创建一个简单的 Java 应用;
# -DinteractiveMode: 是否使用交互模式。
生成的文件测试解释
[root@localhost testdir]# ls # 上述命令执行成功后,会在当前目录下生成以项目名称命名的目录
testapp
[root@maven testdir]# cd testapp/ # 进入
[root@maven testapp]# ls #查看目录下生成的文件
pom.xml src
[root@maven testapp]# cat pom.xml # pom文件参数解释
project: 根,这是对Project添加一些根元素的约束信息
modelversion:指定当前maven模型的版本号
grouopId:应该是公司名或者组织名。一般来说groupID有三个部分组成,每个部分之间以“.”分隔,第一部分是项目的用途,比如用于商业的就是com,用于非商业盈利性组织的就是org,第二部分是公司名,比如tentxun/baidu/alibaba,第三部分是你的项目名
artifactId:可以认为是maven构建的项目名,比如你的项目中有子项目,就可以使用“项目名-子项目的命名方式
packaging: 指定生成的格式(jar/war/rar/pom/ear)
version:版本号,SNAPSHOT意味快照,说明该项目还在开发中,是不稳定的版本
name:项目的名称, Maven产生的文档用
url:项目主页的url,Maven产生的文档用
dependencies标签:指定开发构建(jar包)
JUnit是一个Java语言的单元测试框架
构建项目成功后,也将会在当前用户的宿主目录下生成本地仓库。
[root@maven testapp]# ls ~/.m2/repository/ #查看本地仓库目录结构
antlr asm commons-codec commons-collections commons-io commons-lang jdom net org
[root@maven testapp]# ls ~/.m2/repository/antlr/antlr/2.7.7/
antlr-2.7.7.pom antlr-2.7.7.pom.sha1 _remote.repositories
2)Maven配置文件
Maven 的配置文件名称为:setting.xml。它被存放在两个地方: 、/usr/local/maven/conf/settings.xml #安装的目录 、~/.m2/settings.xml #用户的家目录
其中,安装目录配置又是全局配置,用户目录配置被称为用户配置。如果两者都存在,他们的内容将被合并,并且用户范围的settings.xml优先。
默认用户目录不存在配置文件,可以copy maven安装目录下的settings.xml到用户目录。
关于settings.xml文件常用的的配置修改如下: 1、修改本地仓库存储路径,默认值是~/.m2/repository 可在settings.xml中的localrepository修改成自己需要的目录; 2、如果构建服务器因为网络故障或者安全问题不能与远程仓库相连,需要离线模式下,设置offline属性,设置为true,默认为false; 3、修改中央仓库服务器,修改配置文件中便签,添加或修改镜像地址; 4、设置代理地址,修改配置文件中proxy标签,定义代理服务器,实现maven的代理。
由于中央仓库服务器是国外的,在国内使用的话,下载比较慢,所以建议国内用户使用阿里云仓库地址 3)配置使用阿里云仓库地址
[root@maven testapp]# cd /usr/local/maven/conf/
[root@maven conf]# vim settings.xml
.............................
<url>http://my.repository.com/repo/path</url>
</mirror>
--> # 跳转到158行,写入如下内容
<mirror>
<id>aliyun</id>
<mirrorOf>central</mirrorOf>
<name>aliyun maven</name>
<url>https://maven.aliyun.com/nexus/content/groups/public/</url>
</mirror>
</mirrors> # 在此行上面写入
#mirror就是镜像,主要提供一个方便地切换远程仓库地址的途径
#<mirrorOf>central</mirrorOf>里是要替代的仓库的id。代理原有仓库,如果填写*表示替换所有仓库
4)Maven常用命令
[root@maven testapp]# pwd #确认当前目录是之前构建的项目下
/tmp/testdir/testapp
[root@maven testapp]# mvn compile # 编译(在编译的过程中,可以看到使用的是阿里云的仓库)
[INFO] BUILD SUCCESS # 出现此行说明编译成功
#所有命令都一样,只要最后几行有上述信息,就表示执行成功
[root@maven testapp]# ls target/ #会看到目录下会生成新的目录target
classes maven-status
#target:打包输出目录,如打包好的jar或war文件;
#target/classes:编译输出目录;
[root@maven testapp]# mvn test # 测试命令
[root@maven testapp]# ls target/test-classes/
com
#target/test-classes:测试编译输出目录
[root@maven testapp]# mvn clean #清理命令(就是将编译和测试生成的目录删除)
[root@maven testapp]# ls # 可以看到target目录已经没了
pom.xml src
[root@maven testapp]# mvn package # 打包命令
[root@maven testapp]# ls target/ # 会生成一个jar包
classes maven-archiver maven-status surefire-reports testapp-testapp.jar test-classes
[root@maven testapp]# mvn install #安装命令(作用是将压缩文件jar包或者war包上传到本地仓库)
# 直接使用maven install命令对项目进行上传到本地仓库,
# 那么前面所有的步骤将会自动执行,比如源代码的编译、打包等等。
[root@maven testapp]# mvn deploy #发布(将包上传到私服,现在我这里还没有私服,所以会失败)
5)mvn命令的生命周期 maven基于构建生命周期这个中心概念,这意味着构建和分发特定项目的过程被明确定义,具体如下:
6)构建一个web项目,打出war包,并部署到Tomcat
[root@maven testdir]# mvn archetype:generate -DgroupId=cn.test.testweb -DartifactId=testweb -DarchetypeArtifactId=maven-archetype-webapp -DinteractiveMode=false
#构建web项目
#生成的目录结构如下:
[root@maven testdir]# ls testweb/
pom.xml src
[root@maven testdir]# cat testweb/src/main/webapp/index.jsp
<html>
<body>
<h2>Hello World!</h2>
</body>
</html>
[root@maven testdir]# cd testweb/ #进入项目目录下
[root@maven testweb]# mvn package #打包为war包
[root@maven testweb]# ls target/ # 会生成一个target目录
classes maven-archiver testweb testweb.war
#将生成的war包移动到Tomcat的网页根目录(webapps)下,它将自动解压,
#然后即可访问Tomcat测试生成的war包
#这里自行部署Tomcat (可参考:https://blog.51cto.com/14227204/2466232)
[root@maven testweb]# mv target/testweb.war /usr/local/tomcat/webapps/
[root@maven testweb]# /usr/local/tomcat/bin/startup.sh
[root@maven testweb]# ls /usr/local/tomcat/webapps/ # 可以看到启动之后自行解压
docs examples host-manager manager ROOT testweb testweb.war
客户端访问移动到Tomcat网页根目录下的war包:
Nexus介绍
Nexus 是Maven仓库管理器,如果我们使用Maven,我们可以从Maven中央仓库下载所需要的构件(artifact),但这通常没有公司这么干,一般都是在本地架设一个Maven仓库服务器,在代理远程仓库的同时维护本地仓库,以节省带宽和时间,Nexus就可以满足这样的需要。此外,它还提供了强大的仓库管理功能,构件搜索功能,它基于REST,友好的UI是一个extjs的REST客户端,它占用较少的内存,基于简单文件系统而非数据库。这些优点使其日趋成为最流行的Maven仓库管理器。
Nexus不是Maven的核心概念,它仅仅是一种衍生出来的特殊的Maven仓库。对于Maven来说,仓库只有两种:本地仓库和远程仓库。
本地仓库就是我们在maven的setting.xml中配置的本地仓库地址。由于最原始的本地仓库是空的,Maven必须知道至少一个可用的远程仓库,才能在执行Maven命令的时候下载到需要的构件。中央仓库是maven默认的远程仓库。 当公司架构存在私服的工作流程如下: 私服是架设在局域网的一种特殊的远程仓库,目的是代理远程仓库及部署第三方构件。有了私服之后,当 Maven 需要下载构件时,直接请求私服,私服上存在则下载到本地仓库;否则,私服请求外部的远程仓库,将构件下载到私服,再提供给本地仓库下载。
Nexus的功能如下: 1、节省外网带宽。大量对于外部仓库的重复请求会消耗带宽,利用私服代理外部仓库,可以消除对外的重复构件下载,降低带宽的压力。 2、加速Maven构建。加速Maven构建。不停地连接请求外部仓库十分的耗时,Maven在执行构建的时候不停地检查远程仓库的数据。利用私服,Maven只检查局域网的数据,提高构建的速度。 3、部署第三方构件。部署第三方构件。当某个构件无法从任何一个外部远程仓库获得。建立私服之后,便可以将这些构件部署到私服,供内部的Maven项目使用。 4、提高稳定性,增强控制。提高稳定性,增强控制。Maven构建高度依赖于远程仓库,因此,当网络不稳定的时候,Maven构建也会变得不稳定,甚至无法构建。私服缓存了大量构建,即使暂时没有外网,Maven也可以正常的运行。 5、降低中央仓库的负荷。降低中央仓库的负荷。使用私服可以避免很多对中央仓库的重复下载,降低中央仓库的压力。
1、开始部署Nexus
[root@maven ~]# mkdir /usr/local/nexus
[root@maven ~]# tar zxf nexus-3.17.0-01-unix.tar.gz -C /usr/local/nexus/
#启动nexus必须使用nexus用户,不可以使用权限过高的用户,比如root,否则会启动失败
[root@maven ~]# useradd nexus
[root@maven ~]# chown -R nexus:nexus /usr/local/nexus/
[root@maven ~]# ls /usr/local/nexus/
nexus-3.17.0-01 # 这是应用目录
sonatype-work # 这是工作目录,存放镜像仓库
#运行内存和工作目录nexus-3.17.0-01/bin/nexus.vmoptions (修改对应字段即可)
#运行监听地址和端口nexus-3.17.0-01/etc/nexus-default.properties
[root@maven ~]# ln -s /usr/local/nexus/nexus-3.17.0-01/bin/nexus /usr/local/bin/
#创建命令软连接
#切换至nexus用户,并启动nexus服务,如果使用root用户,会因为权限过高而启动失败
[root@maven ~]# su nexus
[nexus@maven root]$ nexus start
Starting nexus
[root@maven ~]# netstat -anput | grep 8081
tcp 0 0 0.0.0.0:8081 0.0.0.0:* LISTEN 4687/java
启动nexus后,即可访问服务器IP+8081端口:
根据下述提示的路径,查看密码:
[root@maven ~]# cat /usr/local/nexus/sonatype-work/nexus3/admin.password
5af5b7df-3f84-4987-a1fe-0b9c0933d3ad
进行登录,默认的用户名为admin,密码就是我们上面查看到的:
更改admin的密码:
创建角色
点击创建:
创建用户
查看默认仓库类型
仓库类型介绍:
开启release的重复发版权限 开发中需要重复发版,则需要开启release类型仓库的对应权限设置allow redeploy。如下:
设置代理仓库(阿里云maven仓库)
阿里云仓库的URL:https://maven.aliyun.com/nexus/content/groups/public/
填写上述两个内容后,点击页面下边的create repository 创建完成之后可以看到新增加了阿里云库。
将添加的阿里云Proxy加入默认group中:
保存后,再次刷新页面,即可看到当前的Nexus地址:
关于上述配置的常见使用场景介绍如下:
[root@maven conf]# pwd
/usr/local/maven/conf
[root@maven conf]# vim settings.xml
...................
<mirror>
<id>nexus-testconf</id>
<mirrorOf>*</mirrorOf>
<name>nexus testconf</name> <url>http://192.168.171.134:8081/repository/maven-public/</url>
</mirror>
#上面的URL就是在nexus上查看到的URL
</mirrors>
..........................#省略部分内容
#跳转至260行左右,写以下内容
<profile>
<id>testconf</id>
<repositories>
<repository>
<id>nexus</id>
<url>http://192.168.171.134:8081/repository/maven-public/</url>
<releases>
<enable>true</enable>
</releases>
<snapshots>
<enable>true</enable>
</snapshots>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>nexus</id>
<url>http://192.168.171.134:8081/repository/maven-public/</url>
<releases>
<enable>true</enable>
</releases>
<snapshots>
<enable>true</enable>
</snapshots>
</pluginRepository>
</pluginRepositories>
</profile>
</profiles> #在这行上面添加以上内容,这行大概是在260行左右
<activeProfiles>
<activeProfile>testconf</activeProfile>
</activeProfiles>
</settings> #将 <activeProfiles>字段写在settings字段上面
1、创建一个maven项目进行测试
[root@maven conf]# rm -rf ~/.m2/ #先删除本地仓库的缓存
[root@maven testdir]# mvn archetype:generate -DgroupId=cn.zyz.zyzweb -DartifactId=zyzweb -DarchetypeArtifactId=maven-archetype-webapp -DinteractiveMode=false
#构建项目,可以看到在构建的过程中使用的是nexus私服地址。
[root@maven testdir]# ls zyzweb/
pom.xml src
[root@maven testdir]# cd zyzweb/
[root@maven zyzweb]# mvn package #将项目打包
[root@maven zyzweb]# ls #打包后,会生成target目录
pom.xml src target
查看nexus中缓存的文件(若没有缓存文件,下面有解决办法)
如果在以上页面中,并没有看到缓存的文件,是因为当前没有写入nexus的权限,可以进行以下操作:
进行以上设置后,再次删除本地宿主目录下的缓存文件,重新构建项目并打包,即可看到nexus上的缓存文件了。 2、配置认证,将打包好的项目上传到nexus中
[root@maven ~]# vim /usr/local/maven/conf/settings.xml
#搜索“server”字段
<server>
<id>deploymentRepo</id>
<username>repouser</username>
<password>repopwd</password>
</server>
--> #定位到该行,写入以下内容
<server>
<id>test-nexus</id>
<username>testdev</username>
<password>123.com</password>
</server>
修改项目的pod.xml文件:
[root@maven zyzweb]# pwd
/tmp/testdir/zyzweb
[root@maven zyzweb]# ls
pom.xml src
[root@maven zyzweb]# vim pom.xml #编辑配置文件
.....................#省略部分内容,以下内容是手动添加的
<distributionManagement>
<snapshotRepository>
<id>test-nexus</id> #这里的ID必须和上面settings文件中配置认证的ID一致
<name>Nexus Snapshot</name>
<url>http://192.168.171.134:8081/repository/maven-snapshots/</url>
#上面是修订版本的URL,可在nexus的web界面查看
</snapshotRepository>
<repository>
<id>test-nexus</id>
<name>Nexus releases</name>
<url>http://192.168.171.134:8081/repository/maven-releases/</url>
#上面是发行版本的URL,同样在web界面的Repositories中可以查看到
</repository>
</distributionManagement>
</project> #在最后一行上面添加以上内容
[root@maven zyzweb]# mvn deploy # 上传到私服
在web界面确认上传成功:
将所有的内容展开,即可看到以下内容:
如果在部署过程中,出现了错误,首先先检查一下配置文件setting.xml的账号密码有没有与nexus创建的用户密码相同,其次再检查setting.xml里的id标签和pom.xml文件中的id标签是否相同,不同会报401(没有权限)的错误。 3、上传到maven-release仓库
[root@maven zyzweb]# pwd
/tmp/testdir/zyzweb
[root@maven zyzweb]# vim pom.xml
<version>1.0-SNAPSHOT</version>
#将上面这行的“SNAPSHOT”去掉,更改后如下:
<version>1.0</version>
#更改后保存退出即可
[root@maven zyzweb]# mvn deploy
在web界面中查看,如下:
展开所有节点,即可看到以下内容:
配置如下(定义名称并激活),然后自行拖到页面的最下方,点击添加即可
Maven添加第三方仓库地址(全局配置)
#编辑主配置文件
[root@maven zyzweb]# vim /usr/local/maven/conf/settings.xml
#在之前的profiles中,填写以下内容
<repository>
<id>3rdnexus</id> <url>http://192.168.171.134:8081/repository/3rd/</url>
<release>
<enable>true</enable>
</release>
<snapshots>
<enable>true</enable>
</snapshots>
</repository>
</profiles> #添加到这个Profiles标签上面
#在之前的认证字段,再添加一个认证
<server>
<id>test-nexus</id>
<username>testdev</username>
<password>123.com</password>
</server>
<server>
<id>3rdnexus</id> #此ID要与profile中的ID对应
<username>testdev</username>
<password>123.com</password>
</server>
[root@maven testdir]# ls # 上传这个jar包
aliyun-sdk-oss-2.6.1.jar
[root@maven testdir]# mvn deploy:deploy-file -DgroupId=com.aliyun.oss -DartifactId=aliyun-sdk-oss -Dversion=2.6.1 -Dpackaging=jar -Dfile=/tmp/testdir/aliyun-sdk-oss-2.6.1.jar -Durl=http://192.168.171.134:8081/repository/3rd/ -DrepositoryId=3rdnexus
查看本地上传的jar包: