服务器环境搭建-5 Nexus搭建与使用介绍

2024-09-07 22:36

本文主要是介绍服务器环境搭建-5 Nexus搭建与使用介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景

本文介绍nexus的安装、配置和使用,之后通过案例的方式演示使用过程。

1.下载和安装

本文使用Nexus 3.x版本进行演示

下载地址:Download Nexus Repository OSS | Sonatype
国外网站下载速度较慢,也可以通过百度网盘下载(提取码:9999): nexus-3.37.3-02-unix.tar.gz。

2.安装

Nexus使用Java开发的项目,确保环境上已安装JDK

2.1 创建用户

建议使用非root用户启动Nexus(使用root时Nexus会提示不安全),这里可以提前创建一下nexus用户:

#创建nexus群组
groupadd nexus
#创建nexus用户,并指定群组为nexus
useradd nexus -g nexus

2.2 解压缩文件

准备将Nexus安装至/home/seong/nexus/目录下,将下载的资源包上传到该目录下后,执行解压缩文件:

cd /home/seong/nexus/
tar -zxvf nexus-3.37.3-02-unix.tar.gz#更改属组
chown -R /home/seong/nexus/ nexus:nexus

得到的目录结构如下:
在这里插入图片描述
可以看到解压缩后有nexus-${version}sonatype-work两个文件夹,前者负责存放Nexus运行时的数据(理解为数据库),后者负责功能实现(理解为程序)。

2.3 配置Nexus

配置文件在nexus文件夹下, 只需要配置两处即可:
可在etc目录下的nexus-default.properties配置服务的监听端口,此时配置为9001:

[root@VM-4-6-centos etc]# cat nexus-default.properties
# 服务端口
application-port=9001
application-host=0.0.0.0
nexus-args=${jetty.etc}/jetty.xml,${jetty.etc}/jetty-http.xml,${jetty.etc}/jetty-requestlog.xml
# 服务路径
nexus-context-path=/# Nexus section
nexus-edition=nexus-pro-edition
nexus-features=nexus-pro-feature
nexus.hazelcast.discovery.isEnabled=true

JVM运行相关的参数以及数据存储路径可以在bin/nexus.vmoptions文件中进行配置,此时配置堆内存使用1G, 其他使用的默认配置:

-Xms1024m
-Xmx1024m
-XX:MaxDirectMemorySize=2703m
-XX:+UnlockDiagnosticVMOptions
-XX:+LogVMOutput
-XX:LogFile=../sonatype-work/nexus3/log/jvm.log
-XX:-OmitStackTraceInFastThrow
-Djava.net.preferIPv4Stack=true
-Dkaraf.home=.
-Dkaraf.base=.
-Dkaraf.etc=etc/karaf
-Djava.util.logging.config.file=etc/karaf/java.util.logging.properties
-Dkaraf.data=../sonatype-work/nexus3
-Dkaraf.log=../sonatype-work/nexus3/log
-Djava.io.tmpdir=../sonatype-work/nexus3/tmp
-Dkaraf.startLocalConsole=false
-Djdk.tls.ephemeralDHKeySize=2048
-Djava.endorsed.dirs=lib/endorsed

2.3 运行Nexus

进入bin目录,执行运行Nexus的指令:

cd bin# 切换用户后,再启动Nexus
su nexus
./nexus start

nexus除了接收start-启动命令外,还接收stop-停止命令、restart-重启命令。
另外,调试Nexus时,可以通过./nexus run运行Nexux,可以交互式地查看启动日志。

2.4 通过页面配置Nexus

当步骤2.3中启动Nexus成功后,可通过http://ip:9001/访问Nexus:
在这里插入图片描述
用户名为admin, 首次登录时按照提示在服务器上得到密码,登录后需要修改密码:
在这里插入图片描述
输入密码后,建议选择Disable anonymous access禁止匿名访问:
在这里插入图片描述
重新输入用户名和密码,再次登录即可完成安装步骤。
在这里插入图片描述

3.配置仓库镜像地址

按下图步骤进入Nexus的仓库配置页面:
在这里插入图片描述
可以看到Nexus已经帮我们创建了四个仓库:
【1】maven-central: maven中央仓库,存放第三方库依赖包(proxy类型);
【2】maven-releases:本地(私服)的发布仓库, 存放本地发布包(hosted类型);
【3】maven-snapshots:本地的快照仓库,存放本地快照包(hosted类型);
【4】maven-public:public比较特殊,是一个分组(group类型), 包括了maven-central和maven-releases和maven-snapshots,如下所示:
在这里插入图片描述
用户可以只依赖这个public仓库,实现在三个仓库中下载资源。逻辑是:当下载请求到达Nexus仓库时,如果是本地包,会依次尝试从maven-releases和maven-snapshots中下载;如果是第三方库,则会尝试从maven-central仓库下载,如果当前maven-central仓库已有依赖的资源,如:logback-classic:ch.qos.logback:1.2.3已存在,则将资源返回给客户端;如果当前maven-central仓库不存在该依赖包,则Nexus会从配置的仓库下载依赖资源缓存在本地,然后再将资源返回给客户端。
maven-central仓库默认的地址为Maven中央仓库,地址在国外。因此需要为其配置镜像:
在这里插入图片描述
这里使用的阿里云的镜像地址: http://maven.aliyun.com/nexus/content/groups/public/.
至此,Nexus环境已经安装和配置完成。

4.本地配置Nexus仓库

在本地Maven的settings文件中配置Nexus:

<servers><server><id>nexus</id><username>admin</username><password>Nexus登录密码</password></server></servers><mirrors><mirror><id>nexus</id><name>nexus maven</name><mirrorOf>*</mirrorOf><url>http://服务器地址:9001/repository/maven-public/</url></mirror></mirrors>

配置后,以下将结合一个上传和下载案例测试Nexus是否可以正常工作。

5.案例

5.1 下载案例

在这里插入图片描述
由于环境是全新安装,此时maven-central仓库中没有资源:
在这里插入图片描述
本地创建一个maven项目, 仅添加一个日志依赖logback-classic:ch.qos.logback:1.2.3:

<dependency><artifactId>logback-classic</artifactId><groupId>ch.qos.logback</groupId><version>1.2.3</version>
</dependency>

执行mvn clean package时,将通过本地->nexu->阿里云镜像的顺序下载依赖:
在这里插入图片描述下载完成后,再次查看maven-central仓库:
在这里插入图片描述
此时已经将依赖资源缓存到了本地。

5.2 下载案例

新环境没有本地包上传记录,因此maven-releases和maven-snapshots记录为空:
在这里插入图片描述
继续5.1中的案例,将案例项目的坐标信息修改为:

<groupId>com.seong</groupId>
<artifactId>EwenFileSystem</artifactId>
<version>1.0.0</version>

并在pom.xml中添加distributionManagement指定快照和release版本包对应上传仓库的地址:

<distributionManagement><repository><id>nexus</id><name>nexus-releases</name><url>http://服务器IP:9001/repository/maven-releases/</url></repository><snapshotRepository><id>nexus</id><name>nexus-snapshots</name><url>http://服务器IP:9001/repository/maven-snapshots/</url></snapshotRepository>
</distributionManagement>

案例完整的pom文件如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.seong</groupId><artifactId>EwenFileSystem</artifactId><version>1.0.0</version><dependencies><dependency><artifactId>logback-classic</artifactId><groupId>ch.qos.logback</groupId><version>1.2.3</version></dependency></dependencies><distributionManagement><repository><id>nexus</id><name>nexus-releases</name><url>http://服务器IP:9001/repository/maven-releases/</url></repository><snapshotRepository><id>nexus</id><name>nexus-snapshots</name><url>http://服务器IP:9001/repository/maven-snapshots/</url></snapshotRepository></distributionManagement>
</project>

执行mvn clean package打包完成后,再执行mvn deploy操作:
在这里插入图片描述
由于当前项目的坐标不是快照版本,deploy会将包推送至maven-releases仓库;通过Nexus网页查看仓库信息:
在这里插入图片描述
可以看到案例包已经成功推送到了Nexus,后续其他客户端可以从Nexus上下载EwenFileSystem依赖包。

这篇关于服务器环境搭建-5 Nexus搭建与使用介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1146355

相关文章

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma