分布式组件(做成依赖版)

   

   我在做分布式组件时需要将写好的文件上传组件上传到maven私服,现在比较常用的maven私服有Artifactory搭建maven私服,Nexus搭建maven私服,Apache Ar-chiva搭建maven私服(不常用)。

 简介:

(1)nexus是一个强大的maven仓库管理器,它极大的简化了本地内部仓库的维护和外部仓库的访问.
(2)nexus是一套开箱即用的系统不需要数据库,它使用文件系统加Lucene来组织数据
(3)nexus使用ExtJS来开发界面,利用Restlet来提供完整的REST APIs,通过IDEA和Eclipse集成使用
(4)nexus支持webDAV与LDAP安全身份认证.
(5)nexus提供了强大的仓库管理功能,构件搜索功能,它基于REST,友好的UI是一个extjs的REST客户端,占用较少的内存,基于简单文件系统而非数据库.

为什么使用
(1)节省外网带宽。
(2)加速Maven构建。
(3)部署第三方构件。
(4)提高稳定性,增强控制。
(5)降低中央仓库的负荷。
(6)控制和审计
(7)建立本地内部公用仓库
(8)私服仓库的工作流程

Nexus仓库类型介绍
(1)hosted,本地仓库,通常我们会部署自己的构件到这一类型的仓库。比如公司的第二方库。
(2)proxy,代理仓库,它们被用来代理远程的公共仓库,如maven中央仓库。
(3)group,仓库组,用来合并多个hosted/proxy仓库,当你的项目希望在多个repository使用资源时就不需要多次引用了,只需要引用一个group即可。
管理本地仓库
(1)我们前面讲到类型为hosted的为本地仓库,Nexus预定义了3个本地仓库,分别是Releases, Snapshots, 3rd Party. 分别讲一下这三个预置的仓库都是做什么用的:
(2)Releases: 这里存放我们自己项目中发布的构建, 通常是Release版本的, 比如我们自己做了一个FTP Server的项目, 生成的构件为ftpserver.war, 我们就可以把这个构建发布到Nexus的Releases本地仓库. 关于符合发布后面会有介绍.
(3)Snapshots:这个仓库非常的有用,它的目的是让我们可以发布那些非release版本, 非稳定版本, 比如我们在trunk下开发一个项目,在正式release之前你可能需要临时发布一个版本给你的同伴使用, 因为你的同伴正在依赖你的模块开发, 那么这个时候我们就可以发布Snapshot版本到这个仓库, 你的同伴就可以通过简单的命令来获取和使用这个临时版本.
(4)3rd Party:顾名思义, 第三方库, 你可能会问不是有中央仓库来管理第三方库嘛,没错, 这里的是指可以让你添加自己的第三方库, 比如有些构件在中央仓库是不存在的. 比如你在中央仓库找不到Oracle 的JDBC驱动, 这个时候我们就需要自己添加到3rdparty仓库。

docker安装Maven私服nexus3步骤

(1)查找镜像

docker search nexus

(2)拉取镜像

docker pull sonatype/nexus3

(3)启动容器

docker run -d -p 8081:8081 -p 8082:8082 -p 8083:8083 -v /etc/localtime:/etc/localtime --name nexus3   sonatype/nexus3
# -v /home/nexus/nexus-data:/nexus-data 将数据挂载到宿主机
## 8081:nexus3网页端
## 8082:docker(hosted)私有仓库,可以pull和push(后面实现docker的时候会详细说明)
## 8083:docker(proxy)代理远程仓库,只能pull(后面实现docker的时候会详细说明)

(4)查看日志

docker logs nexus3

(5)开放端口

firewall-cmd --zone=public  --permanent --add-port=8081/tcp
firewall-cmd --zone=public  --permanent --add-port=8082/tcp
firewall-cmd --zone=public  --permanent --add-port=8083/tcp

(6)重启防火墙

systemctl restart firewalld

(7)访问

http://localhost:8081/

初始密码为admin/admin123,但是我按照传说中的初始密码发现不正确。

按照提示信息去执行如下步骤即可找到密码。进去之后修改密码为admin123

创建3rd_part库,点击左侧的repository\repositories后,在右侧点击create repository。

然后选择maven2(hosted),填写如下

跳到首页后选择maven-public

将3rd_part移到member中,即将33rd_part由maven-public管理,点击save

至此,创建仓库完成,创建3rd_part管理用户,创建用户: 用户名/密码-dev/dev123

使用dev/dev123登陆,点击upload

填写上传jar包的信息后,点击upload

可以看到已经上传成功

IDE集成依赖

cmd模式

1.复制一份settings.xml为settings-private.xml,在settings-private.xml文件中加入节点server:

<server>
  <id>deployment</id>
  <username>dev</username>
  <password>dev123</password>
</server>

2.在命令行中输入

mvn deploy:deploy-file
-DgroupId=com.sjing.yjyuan
-DartifactId=fastjson-sj
-Dversion=1.0.1
-Dpackaging=jar
-Dfile=E:\installed\mavenRepository\fastjson-1.2.40.jar
-Durl=http://172.16.40.213:8081/repository/3rd_part/
-DrepositoryId=deployment
--settings E:\installed\mavenRepository\settings-private.xml

其中-Durl即3rd_part仓库的地址

-DrepositoryId即为之前server节点中的属性id的值,--settings指定maven的setting文件,即

IDE集成环境

在settings-private.xml中的servers节点加入

<server>
  <id>nexus-release</id>
  <username>dev</username>
  <password>dev123</password>
</server>
<server>
  <id>nexus-snapshots</id>
  <username>dev</username>
  <password>dev123</password>
</server>

在maven工程项目nexus-upload中的pom文件中加入

<!--上传到nexus仓库中,配合mvn deploy:deploy-->
<distributionManagement>
<repository>
     <!--这里的id需要和settings.xml中的server的id一致-->
     <id>nexus-release</id>
     <name>Nexus release Repository</name>
     <!--releases仓库-->
     <url>http://172.16.40.213:8081/repository/maven-releases/</url>
</repository>
<snapshotRepository>
     <id>nexus-snapshots</id>
     <name>Nexus snapshots Repository</name>
     <!--snapshots仓库-->
     <url>http://172.16.40.213:8081/repository/maven-snapshots/</url>
</snapshotRepository>
</distributionManagement>

然后运行mvn deploy

可以在控制台,在nexus私服中可以看到

当然可以在mirror那替换url

项目中添加依赖

我们可以去自己的本地maven仓库看看,是否已经下载下来了呢?

‍分布式组件的上传做成依赖就是这样做的,学会了么?学会了就点个赞。

©️2020 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页