掌握 Maven 私服

前言

在 Java EE 开发中,我们使用 Maven 构建工具主要来管理项目的第三方库的依赖,以及公司内部其他项目服务的依赖,因此 Maven 私服就是必不可少的一环,本文主要对 Maven 私服的三大方面进行介绍:

  • 什么是 Maven 私服
  • 如何搭建 Maven 私服
  • 如何使用 Maven 私服

本文面对的读者应有 Maven 使用经验,了解 Maven 的一些基本概念,如果不太熟悉可以参见文末的参考资料学习。

什么是 Maven 私服

在介绍 Maven 私服之前,我们首先清楚下什么是 Maven 仓库。

Maven 仓库:Maven 统一存储所有Maven项目依赖,插件,以及所上传项目的地方。

并且 Maven 仓库还分成两类:本地仓库和远程仓库。

  • 本地仓库,就是我们本地电脑安装Maven后,在 配置文件 setting.xml里 localRepository 所需要指定目录的那个文件夹。
  • 远程仓库,就是在外部网络里(包括局域网)指定 URL 的专门存放 Java 库,Maven插件等的服务器,,例如中央仓库,就是一个典型的远程仓库,它包含了世界上绝大多数开源的 Java 库,类似的还有许多其他的公开库

而本文提到的私服,就是另一种特殊的远程仓库,它通常架设在局域网内的一台服务器上,用于代理所有外部的远程仓库,并且能接受内部项目的上传和获取。

而这些仓库又有什么用呢?当 Maven 项目需要依赖一些其他项目的 Java 库时,Maven 首先会在本地仓库查找,如果存在对应的库,就直接使用;如果本地仓库不存在,Maven 就会去远程仓库查找,找到对应的 Java 库后下载到本地仓库再使用,以便于下次需要该Java库时,直接使用缓存在本地仓库的依赖库即可,省去了重复通过网络查找并下载的时间,对于 Maven 插件也是同样的过程。

通常情况下,中央仓库是Maven 默认的远程仓库,而当引入了私服后,本地仓库查找结束未找到所需要的依赖库时,就先从私服仓库开始查找,仍未找到的话,最后再去中央仓库查找,具体过程可以参考下图:

在这里我们再看下私服的作用有哪些:

  • 内网访问,节省外网带宽。
  • 一次外网下载,内网所有用户就可以只下载私服缓存,加速 Maven 项目构建。
  • 允许上传和下载私有库,并且不被外部访问,更加安全。
  • 减少外部网络因素,提供项目构建的稳定性。
  • 方便内部项目服务的依赖引用,而不需要其他项目的完整源代码。

这里对最后一小点的作用添加下具体描述:当我们有独立的两个Maven 项目,比如订单服务项目和会员服务项目,其中订单服务项目需要会员服务的调用,依赖了会员服务的 API 包,通过私服可以将编译后的会员服务 API 包上传,然后订单服务程序直接下载引用私服上的会员服务 API 包即可,这样就不需要导入会员服务项目代码,也不用关心会员服务具体实现了,起到了内部服务项目轻度引用的作用,具体过程可参见下图。

搭建 Maven 私服

了解 Maven 私服之后,我们进一步学习。我们首先来搭建一个 Maven 私服。在这里我们使用最流行的开源 Maven 仓库管理软件 - Nexus,来快速搭建 Maven 私服,传统的搭建方式为在 Nexus 官网上下载开源版的 Nexus OSS 进行安装:https://www.sonatype.com/nexus-repository-oss。而本文将采用 Docker 方式安装 Nexus,不仅快速简单,而占用更少的机器资源。

如果对 Docker 不熟悉的同学,可以参见 10分钟快速掌握Docker必备基础知识 学习了解下,简单使用 Docker 也是十分容易的。

下载 Nexus 镜像

在终端控制台上使用 Docker 指令下载 Nexus 官方提供的Docker 镜像:

看到下图结果时,就表示镜像下载完成,可以通过 docker images 查看。

启动 Nexus 容器

使用下方指令启动 Nexus 容器:

在这里对输入的 Docker 指令的参数进行简单的说明:

  • -d 表示让容器后台运行。
  • -p 8081:8081 表示了容器启动时开放内部端口 8081(后者的8081) 映射主机端口的 8081 ,即通过 localhost:8081 可以访问到 Nexus 容器所提供的服务。
  • -v /Users/One/Desktop/Nexus/nexus-data:/nexus-data 表示将容器内部 /nexus-data 挂载到当前主机的指定目录,需要注意的是,-v 指定的外部路径必须为全路径。
  • --restart=always 比较简单,表示当 docker 服务启动时,该容器也跟着启动。

执行上述指令后,稍等片刻,访问 http://localhost:8081/ ,看到对应的 Nexus 后台就表示私服安装完成了,是不是很简单呢。

容器启动过程中,由于机器配置的不同,可能会出现启动慢的情况,只需耐心等待即可。

启动完成后,我们可以在所挂载的本机目录下查看 Nexus 容器运行产生的文件。

配置 Maven 私服

私服安装之后,我们首先进行登录操作,点击页面左上角的 Sign In 按钮,就会出现和下图一样的提示:

说明了 Nexus 默认登录账号为 admin,并且密码位于文件 /nexus-data/admin.password 下,我们只需在本地配置的挂载目录下查看该文件即可。

输入默认的账号密码之后成功登录之后,Nexus 就会强制要求修改 admin 的密码,并且设置基本访问权限,完成之后就正式进入了 Nexus 私服后台。

这里简单对界面元素进行介绍:

  1. 默认的浏览界面,可以搜索查看仓库的组件,以及进行上传操作。
  2. 用于管理私服程序的配置,包括仓库的设置,用户权限管理等。
  3. 账户信息查看,允许修改密码。

进入私服程序的配置界面后,我们需要对默认配置进行几点调整。

中央仓库的代理路径设置

将私服配置里中央仓库的代理仓库路径更新为阿里云仓库提供的代理地址:https://maven.aliyun.com/repository/central 这样一来可以更快速地访问在中央仓库上所需要的依赖和插件。

新建自定义的仓库

首先点击Create repository,然后选择类型为 maven2(hosted)

然后输入仓库名称 private-release,并在 Version policy 一栏中选择 Release,表示这个仓库的存储依赖为正式发布的组件,然后在 Deployment policy 一栏中选择 Allow redeploy,允许部署和更新私服上的组件。

最后点击蓝色按钮 Create repository 之后,就可以在仓库列表看到自定义的仓库了,有了 release 仓库,我们再按照同样方式操作添加一个快照仓库,只需在 Version policy 一栏调整为 Snapshot 即可。

添加角色

Nexus 默认只有两种角色:nx-anonymousnx-admin,前者只有浏览的权限,后者为管理员权限,一般情况下,我们还需要对开发人员创建个角色。点击 Create Role,添加一个 Role ID 为 developer 的自定义角色, 并且只添加自定义仓库的使用权限,删除操作除外。

保存之后,新增的角色就展示在列表中,有了角色,就可以关联用户,进行权限分配了。

添加用户

跟权限类似,默认的用户只有两种:adminanonymous,我们同样需要创建属于开发者的用户对象。点击 Create local user,填入用户名,密码等必填信息之后,关联我们先前的创建的角色,并保存即可。

用户创建完成之后,我们就可以用新的用户登录私服,查看对应权限的内容了,例如我们用新建的用户登录,所能操作的只有查看和搜索自定义的私服仓库。

这样一来我们就创建好了自己的私服仓库,配置完成之后,开发者就可以在 Maven 项目开发中使用了。

使用 Maven 私服

有了私服和用于开发的账号,我们就需要在本地 Maven 配置文件 setting.xml 进行关联。

设置 server 账户信息每个server元素配置指定的仓库ID和用户信息:

设置私服仓库地址:(这里的仓库地址,可以通过 Nexus 后台上仓库页面的 copy 按钮自动复制得到)

Maven 项目部署到私服

配置完成后,我们可以创建一个Maven工程,尝试下打包到 Maven 私服。首先利用 IDE 快速生成 Maven 项目,然后在 POM 文件添加 distributionManagement 节点,并且指定对应的私服仓库 id 和地址,如下:

最后只要执行部署命令 mvn clean deploy 或者利用 IDE 的 部署插件即可,当控制台出现 BUILD SUCCESS 字样,如下图则说明上传私服完成。

从日志上可以看出,我们的项目上传到了 private-snapshot 仓库上,此时我们可以在私服网站上的 private-snapshot 仓库查看到上传的 jar。

如果部署过程中出现如下提示:带有 Access denied to 则说明在 setting.xml 配置的用户权限不足,无法将 jar 部署到对应私服仓库上去。

需要注意的是,对于一个Maven项目而言,如果项目的版本号中有 “SNAPSHOT” 字样,则表示当前处于开发版本,Maven 会将发布到 snapshotRepository 节点对应地址上去。否则,Maven则认为这是一个发布版本,将程序发布到 repository 节点对应的地址上。由于示例项目的版本为 1.0.0-SNAPSHOT ,所以最终项目上传到了 private-snapshot 这个 Snapshot 类型的仓库下。

私服有了这个 jar 之后,如果其他项目要引用时,只需要在其 POM 文件引入对应的坐标即可。

将第三方 jar 包部署到 Maven 私服

本节提到的第三方 jar 包,不是平常所提到的开源库,更多的是来自其他第三方系统的 jar 包,由于项目需要,直接使用 jar 导入的方式来很不方便,更好的处理方式就是将第三方系统的 jar 包手动上传到 Maven 私服上,需要引用的项目直接从私服仓库中拉取即可。

要实现这种效果有两种方法:可视化界面操作和命令行操作。

可视化界面操作:就是在 Nexus 后台上手动上传,执行上传操作必须要对于的上传权限才可以,一般都是管理员账号进行操作,选择仓库后进去上传页面,指定本地需要上传的项目,然后自定义完坐标信息保存即可。

命令行方式:直接在终端输入下面指令即可:

  • -DgroupId 和 -DartifactId 构成了该jar包在 pom.xml 的坐标, 即对应依赖的 groupIdartifactId
  • -Dfile 表示需要上传的jar包的绝对路径
  • -Durl 为私服仓库的url 精确地址
  • -DrepositoryId 为私服仓库定义的id
  • -Dversion 指定了版本号
  • -Dpackaging 指定了打包方式

当控制台日志出现 BUILD SUCCESS 信息时则表示打包成功,如果出现打包失败,很有可能是 Maven 配置文件里 server 元素下的用户权限不足导致,需要 Nexus 后台对用户角色进行上传权限的分配。

结语

在 Java 企业级项目开发中,建立并维护私服是使用 Maven 必不可少的一步,本文从 Maven 的简单介绍,到快速搭建和使用来进一步掌握 Maven 私服,为后续的企业微服务架构做好铺垫。欢迎感兴趣的小伙伴关注留言,相互交流进步?

参考资料

  • Maven入门,读完这篇就够了:https://juejin.im/post/5a4a5e2bf265da4322418d7f#heading-2
  • Maven 实战:https://book.douban.com/subject/5345682/
  • 私服 maven 仓库命令上传 jar 包:https://www.jianshu.com/p/ccd7b643624c
  • What is a Maven Repository:https://medium.com/@chris.shellenbarger/what-is-a-maven-repository-6fa22991fad9

本文分享自微信公众号 - 闻人的技术博客(blog4one),作者:闻人

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-08-27

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 掌握设计模式之装饰者模式

    当应用开发中,我们要为一个对象在原有功能上进行扩展增强时,往往采用继承的方式,而继承过多时就会使得功能类更加复杂,不利于维护,而设计模式中装饰者模式可以帮助我们...

    闻人的技术博客
  • 源码解读 Spring Boot Profiles

    上文《一文掌握 Spring Boot Profiles》 是对 Spring Boot Profiles 的介绍和使用,因此本文将从源码角度探究 Spring...

    闻人的技术博客
  • 快速提升页面性能的必备利器

    从 PC 互联网到移动互联网,越来越多的人在互联网上追剧,看资讯,刷视频,玩游戏等等,与之对应的就是各类互联网应用的用户体验要求越来越高。

    闻人的技术博客
  • 关于分页查询的优化思路(r3笔记第7天)

    目前在生产环境中有一个sql语句执行时间长达7分钟,而且执行频率极高。 其中PROC_INST中有将近6千万的数据。其中STEP_INST是一个物化视图,里面还...

    jeanron100
  • 一天一个设计模式:建造模式

      建造模式是对象的创建模式,建造模式可以将一个产品的内部表象(个人理解,可以称为组件)与产品的生产分割开来,从而可以使一个建造过程生产出来具有不同内部表象的产...

    用户1134788
  • c++ 网络编程(五)TCP/IP LINUX下 socket编程 多种I/O函数 -以及readv和writev函数用法

    原文链接:https://www.cnblogs.com/DOMLX/p/9614056.html

    徐飞机
  • 全景图解高铁数据,谁是最有潜力的高铁城市?

    ? 春节即将倒带,独具中国特色的春运已经启动,据了解,春运期间,预计全国旅客发送量将达到29.8亿人次,与去年基本持平。 近30亿人次是什么概念?相当于把超...

    CDA数据分析师
  • 全景图解高铁数据,谁是最有潜力的高铁城市?

    经过十年的快速发展,高铁已成为人们日常出行的重要交通工具,“千里江陵一日还”早已变成现实,高铁改变的不仅是不断刷新的“中国速度”,更为区域与城市发展带来新的模式...

    华章科技
  • Nginx为什么快到根本停不下来?

    公众号介绍:分享在京东工作的技术感悟,还有JAVA技术和业内最佳实践,大部分都是务实的、能看懂的、可复现的

    公众号_松华说
  • 第六节 服务端负载均衡 zuul

    本质上zuul充当的负载均衡器和路由是一致的,比如请求url: /api/restaurant_server/get 和 /api//user_ser/get ...

    用户1418372

扫码关注云+社区

领取腾讯云代金券