标签:上传 代理 进入 jre rac 需求 网址 网络故障 应用程序
博文大纲:
一、Maven简介
1)Maven的功能:
2)Maven使用场景(从运维人员的角度来看):
3)Maven仓库
二、部署Maven
1)配置jdk环境
2)部署Maven
三、部署Nexus私服
1)Nexus简介
2)部署Nexus
四、Maven配置nexus私服,将远程仓库设置成本地搭建的Nexus私服
1)修改maven的主配置文件
2)创建一个maven项目进行测试
3)配置认证,将打包好的项目上传到nexus中
4)上传到maven-release仓库
5)上传第三方maven
Maven是属于apache软件基金会下一个开源免费的项目,是跨平台的项目管理工具, Maven采用了一种被称之为Project Object Model (POM)概念来管理项目,所有的项目配置信息都被定义在一个叫做POM.xml的文件中。主要服务于基于Java平台的项目构建,依赖管理和项目信息管理,可以在代码进行部署的过程中自动解决项目中代码的依赖环境,需要从maven的镜像仓库中进行下载依赖环境,通常下载比较慢,企业中会在公司内部搭建nexus(私服),将构建项目中的依赖环境保存到nexus服务器中,提高访问速度。
POM项目对象模型,是Maven工程的基本工作单元,是一个XML文件,包含了项目的基本信息,用于描述项目如何构建,声明项目依赖等等。
执行任务或目标时,Maven会在当前目录中查找POM。读取POM,获取所需的配置信息,然后执行目标。
POM中可以指定以下配置:项目依赖、插件、执行目标、项目构建profile、项目版本、项目开发列表、相关邮件列表信息。
1)1. mavne模型的Java项目对源代码、单元测试代码、资源、jar包等有规范和目录规划;
2)2. 解决项目间的依赖关系、版本不一致、版本冲突问题;
3)3. 合理的jar管理机制;
1)原来项目中的jar包必须手动复制、粘贴到WEB-INF/lib项目下,而借助maven,可以将jar包仅仅保存在仓库中,有需要使用的工程只需要引用这个文件,并不需要重复复制到工程中;
2)原来的项目中所需要的jar包都是提前下载好的,而maven在联网状态下会自动下载所需要的jar包。首先在本地仓库中找,找不到就在网上进行下载;
3)原来的项目中一个jar包所依赖的其他jar包必须手动导进来,而maven会自动将被依赖的jar包导进来;
4)原来的项目一个项目就是一个工程,而借助maven可以将一个项目拆分成多个工程;
项目构建过程包括:【清理项目】→【编译项目】→【测试项目】→【生成测试报告】→【打包项目】→【部署项目】这几个步骤,这六个步骤就是一个项目的完整构建过程。
在Maven的专业术语中,仓库是指一个位置,Maven仓库是项目中依赖的第三方库,这个库所在的位置叫做仓库。在Maven中,任何一个依赖、插件或者项目构建的输出,都可以称之为构件。
Maven仓库能帮助我们管理构件(主要是Jar),它就是放置所有JAR文件(WAR、ZIP、POM等等)的地方。
Maven仓库有三种类型:本地、中央、远程。
Maven 的本地仓库,在安装 Maven 后并不会创建,它是在第一次执行 maven 命令的时候才被创建。
运行 Maven 的时候,Maven 所需要的任何构件都是直接从本地仓库获取的。如果本地仓库没有,它会首先尝试从远程仓库下载构件至本地仓库,然后再使用本地仓库的构件。
默认情况下,不管Linux还是 Windows,每个用户在自己的用户目录下都有一个路径名为 .m2/respository/ 的仓库目录。
Maven中央仓库是由Maven社区提供的仓库,其中包含了大量常用的库。
maven内置了远程公用仓库:http://repo1.maven.org/maven2 。
中央仓库包含了绝大多数流行的开源Java构件,以及源码、作者信息、SCM、信息、许可证信息等。一般来说,简单的Java项目依赖的构件都可以在这里下载到。
第三方仓库又称为内部中心仓库,也称为私服。
私服:一般是由公司自己设立的,只为公司内部共享使用。它既可以作为公司内部构件协作和存档,也可以作为公用类库镜像缓存,减少在外部访问和下载的频率(使用了私服就减少了对中央仓库的访问)。
如需了解更多,可以移步这篇文档:Maven教程
安装Maven需依赖java环境,所以应实现部署jdk环境!
注:该博文用到的所有源码包都可以从我提供的网盘链接中下载
[root@maven ~]# rpm -qa | grep jdk //查询本机默认JDK环境
java-1.8.0-openjdk-headless-1.8.0.161-2.b14.el7.x86_64
copy-jdk-configs-3.3-2.el7.noarch
java-1.7.0-openjdk-headless-1.7.0.171-2.6.13.2.el7.x86_64
java-1.7.0-openjdk-1.7.0.171-2.6.13.2.el7.x86_64
java-1.8.0-openjdk-1.8.0.161-2.b14.el7.x86_64
[root@maven ~]# yum -y remove java-1.7.0-openjdk-headless-1.7.0.171-2.6.13.2.el7.x86_64
[root@maven ~]# yum -y remove java-1.8.0-openjdk-headless-1.8.0.161-2.b14.el7.x86_64
//将原本的jdk-headless包卸载
[root@maven ~]# tar zxf jdk-8u211-linux-x64.tar.gz -C /usr/local //将提供的JDK软件包进行解压
[root@maven ~]# vim /etc/profile //编写系统环境变量,在末尾添加以下内容
export JAVA_HOME=/usr/local/jdk1.8.0_211 //指定Java安装路径
export JRE_HOME=/usr/local/jdk1.8.0_211/jre //Java运行环境
export CLASSPATH=$JAVA_HOME/lib/tools.jar:$JAVA_HOME/lib/dt.jar //声明Java中的类,类就是一类事务的属性
export PATH=$JAVA_HOME/bin/:$JRE_HOME/bin/:$PATH //将定义的变量添加到系统环境变量中
[root@maven ~]# source /etc/profile //重新加载系统环境变量文件
[root@maven ~]#java -version //查询支持的Java版本信息
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)
[root@maven ~]# wget http://mirrors.tuna.tsinghua.edu.cn/apache/maven/maven-3/3.6.3/binaries/apache-maven-3.6.3-bin.tar.gz
#可直接使用网盘中的apache-maven-3.6.1-bin.tar.gz
[root@maven ~]# tar zxf apache-maven-3.6.3-bin.tar.gz -C /usr/src
[root@maven ~]# mv /usr/src/apache-maven-3.6.3/ /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.3 (cecedd343002696d0abb0b32b541b8a6ba2883f)
Maven home: /usr/local/maven
Java version: 1.8.0_211, vendor: Oracle Corporation, runtime: /usr/local/jdk1.8.0_211/jre
Default locale: zh_CN, platform encoding: UTF-8
OS name: "linux", version: "3.10.0-862.el7.x86_64", arch: "amd64", family: "unix"
由于使用maven官网的地址。下载较慢,所以直接更改为阿里云提供的maven仓库地址!
[root@maven ~]# vim /usr/local/maven/conf/settings.xml
#定位到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。代理原有仓库,如果填写*表示替换所有仓库
[root@maven ~]# mkdir /tmp/testdir
[root@maven ~]# cd /tmp/testdir/
#执行下面命令进行测试
[root@maven testdir]# mvn archetype:generate -DgroupId=com.lzj.maven.quickstart -DartifactIdk=testapp -DarchetypeArtifactId=maven-archetype-quickstart
#创建一个maven项目(Java类型),可加-DinteractiveMode=false取消交互过程
...........................#省略部分内容
Define value for property ‘artifactId‘: testapp #需手动指定项目名称,可自定义,接下来保持默认即可!
[INFO] BUILD SUCCESS #当出现这行提示信息,则表示构建成功
#上述命令解释如下:
# archetype:generate:创建一个简单的java项目;
# archetype 也就是原型,是一个 Maven 插件,准确说是一个项目模板,它的任务是根据模板创建一个项目结构。
#使用 quickstart 原型插件创建一个简单的 java 应用程序
# -DgroupId:组织名,公司网址的反写(反向域名)+项目名称;
# -DartifactIdk:项目名或者模块名;
# - DarchetypeArtifactId:指定 ArchetypeId,maven-archetype-quickstart,创建一个简单的 Java 应用;
# -DinteractiveMode: 是否使用交互模式。
当前目录生成的内容:
[root@maven 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 testdir]# ls ~/.m2/repository/
antlr asm commons-codec commons-collections commons-io commons-lang jdom net org
Maven 的配置文件名称为:setting.xml。它被存放在两个地方:
1)/usr/local/maven/conf/settings.xml #安装的目录;
2)~/.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的代理。
由于中央仓库服务器是国外的,在国内使用的话,下载比较慢,所以建议国内用户使用阿里云仓库地址。
[root@maven testapp]# pwd #确认当前目录是之前构建的项目下
/tmp/testdir/testapp
[root@maven testapp]# mvn compile #编译(在编译的过程中,可以看到使用的是阿里云的仓库)
[INFO] BUILD SUCCESS #只要在输出信息的最后几行中看到该行,则表示执行成功
#以后所有命令都一样,只要最后几行有上述信息,就表示执行成功
[root@maven testapp]# ls #会看到目录下会生成新的目录target
pom.xml src target
# 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 surefire-reports
maven-archiver testapp-1.0-SNAPSHOT.jar
maven-status test-classes
[root@maven testapp]# mvn install #安装命令(作用是将压缩文件jar包或者war包上传到本地仓库)
[root@maven testapp]# ls ~/.m2/repository/com/lzj/maven/quickstart/testapp/1.0-SNAPSHOT/
#查看上传的包
maven-metadata-local.xml testapp-1.0-SNAPSHOT.jar
_remote.repositories testapp-1.0-SNAPSHOT.pom
# 直接使用maven install命令对项目进行上传到本地仓库,
# 那么前面所有的步骤将会自动执行,比如源代码的编译、打包等等。
[root@maven testapp]# mvn deploy #发布(将包上传到私服,现在我这里还没有私服,所以会失败)
maven基于构建生命周期这个中心概念,这意味着构建和分布特定项目的过程被明确定义,具体如下:
大致的生命周期图:
详细的生命周期图:
[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/ #将会在该目录下生成一个war包
classes maven-archiver testweb testweb.war
#将生成的war包移动到Tomcat的网页根目录(webapps)下,它将自动解压,
#然后即可访问Tomcat测试生成的war包
[root@maven testweb]# wget http://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-9/v9.0.31/bin/apache-tomcat-9.0.31.tar.gz
[root@maven testweb]# tar zxf apache-tomcat-9.0.31.tar.gz
[root@maven testweb]# mv apache-tomcat-9.0.31 /usr/local/tomcat #安装tomcat
[root@maven testweb]# mv target/testweb.war /usr/local/tomcat/webapps/ #移动到Tomcat网页根目录
[root@maven testweb]# /usr/local/tomcat/bin/startup.sh #启动Tomcat
[root@maven testweb]# ls /usr/local/tomcat/webapps/ #查看,war包被自动解压了
docs host-manager ROOT testweb.war
examples manager testweb
客户端访问移动到Tomcat网页根目录下的war包,如图:
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)降低中央仓库的负荷。降低中央仓库的负荷。使用私服可以避免很多对中央仓库的重复下载,降低中央仓库的压力。
这个软件从官网下载较慢,可从博文开头的网盘链接中获取!
[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 ~]# cd /usr/local/nexus/
[root@maven nexus]# ls
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 nexus]# ln -s /usr/local/nexus/nexus-3.17.0-01/bin/nexus /usr/local/bin/
#创建命令软连接
#切换至nexus用户,并启动nexus服务,如果使用root用户,会因为权限过高而启动失败
[root@maven nexus]# su nexus
[nexus@maven nexus]$ nexus start #启动nexus
Starting nexus
[root@maven nexus]# netstat -anpt | grep 8081 #默认监听8081端口
tcp 0 0 0.0.0.0:8081 0.0.0.0:* LISTEN 61881/java
启动成功,浏览器进行访问:
[root@maven ~]# cat /usr/local/nexus/sonatype-work/nexus3/admin.password
da8b24ed-8bd2-42c5-864f-858216a21cf4 #复制查看出的密码信息
如图:
如图:
如图:
默认的仓库类型介绍:
- group(仓库组类型):又叫组仓库,用于方便开发人员,自己设定的仓库
- hosted(宿主类型):内部项目的发布仓库(内部开发人员发布上去存放的仓库);
- proxy(代理类型):从远程中央仓库中寻找数据的仓库(可以点击对应的仓库的Configuration页签下Remote Storage Location属性的值,即被代理的远程仓库的路径);
- virtual(虚拟类型):虚拟仓库(这个基本上用不到);
Public Repositories下的仓库类型:
- 3rd party::无法从公共仓库获得的第三方发布版本的构件仓库,即第三方依赖的仓库,这个数据通常是由内部人员自行下载之后发布上去;
- Apache Snapshots: 用了代理ApacheMaven仓库快照版本的构件仓库
- Central::用来代理maven中央仓库中发布版本构件的仓库
- entral M1 shadow::用于提供中央仓库中M1格式的发布版本的构件镜像仓库
- Codehaus Snapshots::用来代理CodehausMaven 仓库的快照版本构件的仓库
- Releases::内部的模块中release模块的发布仓库,用来部署管理内部的发布版本构件的宿主类型仓库;release是发布版本;
- Snapshots:发布内部的SNAPSHOT模块的仓库,用来部署管理内部的快照版本构件的宿主类型仓库;snapshots是快照版本,也就是不稳定版本;
开发中需要重复发版,则需要开启release类型仓库的对应权限设置allow redeploy。如下:
如图:
阿里云仓库的URL:https://maven.aliyun.com/nexus/content/groups/public/
如图:
保存后,再次刷新页面,即可看到当前的Nexus地址:
关于上述配置的常见使用场景介绍如下:
- release发版仓库(nexus默认已建立:maven-releasees);
- snapshot 测试中心快照仓库(nexus默认已建立:maven-snapshots);
- central 中央仓库 (nexus默认已建立:maven-central);
关于组:在nexus中可以建立组,将不同类型仓库集合在一起(nexus默认已建立:maven-public)
- 场景一: 自定义新建proxy类型仓库,在maven配置中分别配置不同调用地址,或是将自定义新建的proxy仓库统一加入一个组,在maven配置中调用一个地址;
- 场景二: 使用maven已经建立好的proxy仓库,且使用已建立好的组(maven-public)配置maven调用地址;
场景一和场景二本质上讲没有什么变化,根据公司开发习惯和需求进行配置即可!
[root@maven ~]# vim /usr/local/maven/conf/settings.xml
………………………… #省略部分内容
<mirror>
<id>nexus-testconf</id>
<mirrorOf>*</mirrorOf>
<name>nexus testconf</name>
<url>http://192.168.1.7:8081/repository/maven-public/</url>
</mirror>
#上面的URL就是在nexus上查看到的URL
</mirrors>
..........................#省略部分内容
#跳转至260行左右,写以下内容
<profile>
<id>testconf</id>
<repositories>
<repository>
<id>nexus</id>
<url>http://192.168.1.7: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.1.7:8081/repository/maven-public/</url>
<releases>
<enable>true</enable>
</releases>
<snapshots>
<enable>true</enable>
</snapshots>
</pluginRepository>
</pluginRepositories>
</profile>
</profiles> #需在该标签以上进行添加!
..........................#省略部分内容
<activeProfiles>
<activeProfile>testconf</activeProfile> #这里的值一定要和上面profile的ID对应,才可以激活
</activeProfiles>
</settings> #将 <activeProfiles>字段写在settings字段上面
需首先开启匿名写入nexus的权限,如下:
[root@maven ~]# rm -rf ~/.m2/ #先删除本地仓库的缓存
[root@maven ~]# cd /tmp/testdir/
[root@maven testdir]# mvn archetype:generate -DgroupId=cn.ljz.ljzweb -DartifactId=lzjweb -DarchetypeArtifactId=maven-archetype-webapp -DinteractiveMode=false
#构建项目,可以看到在构建的过程中使用的是nexus私服地址。
[root@maven testdir]# cd lzjweb/ #进入构建后的项目
[root@maven lzjweb]# mvn package #将项目打包
[root@maven lzjweb]# ls #打包后,会生成target目录
pom.xml src target
web页面进行查看:
[root@maven lzjweb]# vim /usr/local/maven/conf/settings.xml
#搜索“server”字段
<server>
<id>deploymentRepo</id>
<username>repouser</username>
<password>repopwd</password>
</server>
--> #定位到该行,写入以下内容,大概是124行
<server>
<id>test-nexus</id> #自定义ID
<username>testdevops</username> #刚开始在nexus的web页面添加的用户名ID号
<password>123456</password> #用户名密码
</server>
#修改项目中的pod.xml文件
[root@maven lzjweb]# pwd
/tmp/testdir/lzjweb
[root@maven lzjweb]# ls
pom.xml src target
[root@maven ljzweb]# vim pom.xml #编辑配置文件
.....................#省略部分内容,以下内容是手动添加的
<distributionManagement>
<snapshotRepository>
<id>test-nexus</id> #这里的ID必须和上面settings文件中配置认证的ID一致
<name>Nexus Snapshot</name>
<url>http://192.168.1.7:8081/repository/maven-snapshots/</url>
#上面是修订版本的URL,可在nexus的web界面查看
</snapshotRepository>
<repository>
<id>test-nexus</id>
<name>Nexus releases</name>
<url>http://192.168.1.7:8081/repository/maven-releases/</url>
#上面是发行版本的URL,同样在web界面的Repositories中可以查看到
</repository>
</distributionManagement>
</project> #在最后一行上面添加以上内容
web页面进行查看:
如果在部署过程中,出现了错误,首先先检查一下配置文件setting.xml的账号密码有没有与nexus创建的用户密码相同,其次再检查setting.xml里的id标签和pom.xml文件中的id标签是否相同,不同会报401(没有权限)的错误。
[root@maven lzjweb]# vim /tmp/testdir/lzjweb/pom.xml
……………… #省略部分内容
<version>1.0-SNAPSHOT</version>
#将上面这行的“SNAPSHOT”去掉,更改后如下:
<version>1.0</version>
[root@maven lzjweb]# mvn deploy #再次上传
web页面进行查看:
如图:
Maven添加第三方仓库地址(全局配置)
[root@maven lzjweb]# vim /usr/local/maven/conf/settings.xml
#在之前的profiles(闭合标签差不多在293行),填写以下内容
<repository>
<id>3rdnexus</id>
<url>http://192.168.1.7:8081/repository/3rd/</url>
<release>
<enable>true</enable>
</release>
<snapshots>
<enable>true</enable>
</snapshots>
</repository>
</profiles> #添加到这个Profiles标签上面(添加之前应该是293行)
#在之前的认证字段,再添加一个认证
<server>
<id>test-nexus</id>
<username>testdevops</username>
<password>123456</password>
</server> #此行以上是之前添加的,再次添加以下内容
<server>
<id>3rdnexus</id> #此ID要与profile中的ID对应
<username>testdevops</username>
<password>123456</password>
</server>
[root@maven testdir]# ll aliyun-sdk-oss-2.6.1.jar
-rw-r--r-- 1 root root 470115 10月 10 17:43 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.1.7:8081/repository/3rd/ -DrepositoryId=3rdnexus
#基于本地的jar包构建项目
web页面查看上传的jar包:
———————————— 本文至此结束,感谢阅读 ————————————
标签:上传 代理 进入 jre rac 需求 网址 网络故障 应用程序
原文地址:https://blog.51cto.com/14157628/2472382