Maven私服-Nexus3安装与使用

写在前面
安装简单,此博客主要是为了记录下怎么使用,以及一些概念性的东西

安装+配置

下载

下载对应版本(科学上网)
https://help.sonatype.com/en/download-archives—repository-manager-3.html

设置端口

/etc/nexus-default.properties
修改端口号
在这里插入图片描述

启动

进入/bin目录执行nexus 命令(./nexus run)

./nexus stop 关闭
./nexus run 开启
./nexus {start|stop|run|run-redirect|status|restart|force-reload}

登录

首次登录他会告诉你初始密码是在哪个目录下(我的是nexus-3.70.3-01如果你是旧版本 账户密码分别是admin admin123)
在这里插入图片描述

修改默认代理仓库

修改为https://maven.aliyun.com/repository/public
在这里插入图片描述

使用

默认仓库介绍

1)maven-central:maven中央库,默认https://repo1.maven.org/maven2/拉取jar

2)maven-releases:私库发行版jar

3)maven-snapshots私库快照(调试版本)jar

4)maven-public:仓库分组,把上面三个仓库组合在一起对外提供服务,在本地maven基础配置settings.xml中使用。

仓库类型

1)group(仓库组类型):又叫组仓库,用于方便开发人员自己设定的仓库;

2)hosted(宿主类型):内部项目的发布仓库(内部开发人员,发布上去存放的仓库);

3)proxy(代理类型): 从远程中央仓库中寻找数据的仓库(可以点击对应的仓库的Configuration页签下Remote Storage Location属性的值即被代理的远程仓库的路径);

4)virtual(虚拟类型): 虚拟仓库(这个基本用不到,重点关注上面三个仓库的使用)

版本策略

Release: 正式版本
Snapshot: 快照版本
Mixed: 混合模式

部署策略

‌Allow Redeploy‌:允许重新部署应用程序。开发人员可以对应用程序进行修改、更改配置或更新代码,并将这些更改重新部署到运行中的应用程序中。
‌使用场景‌:通常用于开发和测试环境,以便验证和应用修改的效果。
‌Disable Redeploy‌:禁用重新部署功能,阻止在应用程序运行时修改代码或更改配置。
‌使用场景‌:主要用于生产环境,以确保系统的稳定性和安全性,防止运行时修改可能导致的问题。

‌Deploy by Replication Only‌:仅通过复制机制进行部署。多个节点具有相同的应用程序代码、配置和数据副本,每个节点都可以独立地提供服务。当一个节点失效时,其他节点可以接管其功能,确保系统的可用性和稳定性。
‌使用场景‌:适用于需要高可用性和负载均衡的环境,确保系统的稳定运行。

‌ReadOnly‌:只读模式。在这种模式下,仓库中的构件只能被读取,不能进行上传或更新操作。这种策略适用于需要保护现有构件不被修改的场景。
使用场景‌:适用于只读场景,如提供公共库的访问,确保数据不被篡改。

访问规则

在这里插入图片描述

新建仓库

这里我打算新建一个宿主仓库thirdparty,然后将其分组到默认的public分组中
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

代码相关的配置

setting文件

<?xml version="1.0" encoding="UTF-8"?>
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
			xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
			xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0
			http://maven.apache.org/xsd/settings-1.0.0.xsd">
    <!-- offline
   | 当没有网络,只有本地库,又是用maven来管理项目,在编译或者下载第三方Jar的时候,老是去中央仓库上自动下载jar,
   | 但实际本地已存在这些jar,导致出问题, 那么就可以试下使用离线模式
   |
   | 默认值: false
  <offline>false</offline>
  -->
    <pluginGroups>
    </pluginGroups>

    <proxies>
    </proxies>

    <servers>
        <!--配置nexus仓库认证信息-->
        <server>
            <id>lylpb-releases</id>
            <username>admin</username>
            <password>admin123</password>
        </server>
        <server>
            <id>lylpb-snapshots</id>
            <username>admin</username>
            <password>admin123</password>
        </server>
 	  <server>
            <id>lylpb-nexus</id>
            <username>admin</username>
            <password>admin123</password>
        </server>
    </servers>

    <mirrors>
        <!-- 所有maven下载都通过本地nexus私服 -->
        <mirror>
            <id>lylpb-nexus</id>
            <name>local nexus maven</name>
            <mirrorOf>*</mirrorOf>
            <url>http://192.168.150.129:10081/repository/maven-public/</url>
        </mirror>
    </mirrors>

    <profiles>

      <profile>
         <id>lylpb-nexus</id>
	    <!-- 远程仓库 -->
         <repositories>
          <repository>
            <id>nexus</id>
            <name>Nexus Repository</name>
		<!-- 虚拟的URL形式,指向镜像的URL-->
            <url>http://192.168.150.129:10081/repository/maven-public/</url>
            <layout>default</layout>
		<!-- 表示可以从这个仓库下载snapshot版本的构件 -->   
            <snapshots>
              <enabled>true</enabled>
            </snapshots>
	      <!-- 表示可以从这个仓库下载releases版本的构件--> 
           <releases>
              <enabled>true</enabled>
            </releases>
          </repository>
        </repositories>
		
	  <!-- 插件仓库列表 -->
        <pluginRepositories>
          <pluginRepository>
              <id>lylpb-nexus</id>
              <name>Nexus Repository</name>
              <url>http://192.168.150.129:10081/repository/maven-public/</url>
              <layout>default</layout>
              <snapshots>
                <enabled>true</enabled>
              </snapshots>
              <releases>
                <enabled>true</enabled>
              </releases>
          </pluginRepository>
        </pluginRepositories>
      </profile>

    </profiles>

     <!-- 激活的环境 -->
    <activeProfiles>
      <activeProfile>lylpb-nexus</activeProfile>
    </activeProfiles>
</settings>

项目中的自动化部署(distributionManagement配置)

pom文件中加入distributionManagement,id与setting配置文件的id保持匹配

    <distributionManagement>
        <snapshotRepository>
            <id>lylpb-snapshots</id>
            <name>snapshots</name>
            <url>http://192.168.150.129:10081/repository/maven-snapshots/</url>
        </snapshotRepository>
        <repository>
            <id>lylpb-releases</id>
            <name>releases</name>
            <url>http://192.168.150.129:10081/repository/maven-releases/</url>
        </repository>
    </distributionManagement>

上传第三方jar包到私服

mvn deploy:deploy-file --settings settings-my.xml -DgroupId=com.infiniteautomation2 -DartifactId=modbus4j -Dversion=3.1.0 -Dpackaging=jar -Dfile=modbus4j-3.1.0.jar -Durl=http://192.168.150.129:10081/repository/thirdparty/ -DrepositoryId=lylpb-nexus

-DrepositoryId 参数用于指定 Maven 部署文件时所使用的仓库 ID。这个仓库 ID 必须在你的 settings.xml 文件中定义,以便 Maven 知道如何认证和连接到该仓库。
–settings 配置文件地址改成自己的文件地址

执行完成后能找到对应的包 并在指定仓库中
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/956829.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

MindAgent:基于大型语言模型的多智能体协作基础设施

2023-09-18 &#xff0c;加州大学洛杉矶分校&#xff08;UCLA&#xff09;、微软研究院、斯坦福大学等机构共同创建的新型基础设施&#xff0c;目的在评估大型语言模型在游戏互动中的规划和协调能力。MindAgent通过CuisineWorld这一新的游戏场景和相关基准&#xff0c;调度多智…

【k8s面试题2025】2、练气初期

在练气初期&#xff0c;灵气还比较稀薄&#xff0c;只能勉强在体内运转几个周天。 文章目录 简述k8s静态pod为 Kubernetes 集群移除新节点&#xff1a;为 K8s 集群添加新节点Kubernetes 中 Pod 的调度流程 简述k8s静态pod 定义 静态Pod是一种特殊类型的Pod&#xff0c;它是由ku…

K8S-Pod资源清单的编写,资源的增删改查,镜像的下载策略

1. Pod资源清单的编写 1.1 Pod运行单个容器的资源清单 ##创建工作目录 mkdir -p /root/manifests/pods && cd /root/manifests/pods vim 01-nginx.yaml ##指定api版本 apiVersion: v1 ##指定资源类型 kind: Pod ##指定元数据 metadata:##指定名称name: myweb ##用户…

编辑器Vim基本模式和指令 --【Linux基础开发工具】

文章目录 一、编辑器Vim 键盘布局二、Linux编辑器-vim使用三、vim的基本概念正常/普通/命令模式(Normal mode)插入模式(Insert mode)末行模式(last line mode) 四、vim的基本操作五、vim正常模式命令集插入模式从插入模式切换为命令模式移动光标删除文字复制替换撤销上一次操作…

深度学习 DAY1:RNN 神经网络及其变体网络(LSTM、GRU)

实验介绍 RNN 网络是一种基础的多层反馈神经网络&#xff0c;该神经网络的节点定向连接成环&#xff0c;其内部状态可以展示动态时序行为。相比于前馈神经网络&#xff0c;该网络内部具有很强的记忆性&#xff0c;它可以利用它内部的记忆来处理任意时序的输入序列&#xff0c;…

svn tag

一般发布版本前&#xff0c;需要在svn上打个tag。步骤如下&#xff1a; 1、空白处右击&#xff0c;选择TortoiseSVN->Branch/tag; 2、填写To path&#xff0c;即tag的路基以及tag命名&#xff08;一般用版本号来命名&#xff09;&#xff1b;填写tag信息&#xff1b;勾选cr…

Astropay之坑

大家可能知道 Astropay 原来在日本也有业务&#xff0c;后来突然有一天业务关掉了&#xff0c;那里面的用户的钱当然也就取不出来了嘛。 我合计那就那么放着呗&#xff0c;等以后你们重返日本的时候我再去取嘛。 嗨&#xff0c;最近收到几个邮件&#xff0c;可把我气笑了。 简…

(7)(7.2) 围栏

文章目录 前言 1 通用设置 2 围栏类型 3 破坏栅栏行动 4 使用 RC 通道辅助开关启用栅栏 5 自动高度规避 6 在任务规划器中启用围栏 7 用于遥控飞行训练 8 MAVLink 支持 前言 ArduPilot 支持基于本机的圆柱形&#xff08;“TinCan”&#xff09;和多边形和/或圆柱形、…

ARP 表、MAC 表、路由表、跨网段 ARP

文章目录 一、ARP 表1、PC2、路由器 - AR22203、交换机 - S57004、什么样的设备会有 ARP 表&#xff1f; 二、MAC 表什么样的设备会有 MAC 表&#xff1f; 三、路由表什么样的设备会有路由表&#xff1f; 四、抓取跨网段 ARP 包 所谓 “透明” 就是指不用做任何配置 一、ARP 表…

信号与系统学习(二)

1.3信号的分类&#xff1a;能量与功率信号&#xff0c;因果与反因果 1.能量信号和功率信号 将信号f(t)施加与1Ω电阻上&#xff0c;它所消耗的瞬时功率为|f(t)|&#xff0c;在区间&#xff08;-∞&#xff0c;∞&#xff09;的能量和平均功率定义为 能量有限信号&#xff1a;…

k8s的CICD实施项目

环境需求&#xff1a; 目前领导需要做一个需求&#xff0c;临时把我从运维岗位&#xff0c;把我调度到到专家组让我主导cicd的项目实施 目前环境资源 k8s环境&#xff0c;28台服务器&#xff0c;上面是k8s集群&#xff0c;要实施一个测试环境的cicd以及一个生产环境的cicd gitl…

python轻量级框架-flask

简述 Flask 是 Python 生态圈中一个基于 Python 的Web 框架。其轻量、模块化和易于扩展的特点导致其被广泛使用&#xff0c;适合快速开发 Web 应用以及构建小型到中型项目。它提供了开发 Web 应用最基础的工具和组件。之所以称为微框架&#xff0c;是因为它与一些大型 Web 框架…

uniapp——App 监听下载文件状态,打开文件(三)

5 实现下载文件并打开 这里演示&#xff0c;导出Excel 表格 文章目录 5 实现下载文件并打开DEMO监听下载进度效果图为什么 totalSize 一直为0&#xff1f; 相关Api&#xff1a; downloader DEMO 提示&#xff1a; 请求方式支持&#xff1a;GET、POST&#xff1b;POST 方式需要…

Java设计模式—观察者模式

观察者模式 目录 观察者模式1、什么是观察者模式&#xff1f;2、观察者模式优缺点及注意事项&#xff1f;3、观察者模式实现&#xff1f;4、手写线程安全的观察者模式&#xff1f; 1、什么是观察者模式&#xff1f; - 实例&#xff1a;现实生活中很多事物都是依赖存在的&#x…

大象机器人发布首款穿戴式数据采集器myController S570,助力具身智能数据收集!

myController S570 具有较高的数据采集速度和远程控制能力&#xff0c;大大简化了人形机器人的编程。 myController S570 是一款可移动的轻量级外骨骼&#xff0c;具有 14 个关节、2 个操纵杆和 2 个按钮&#xff0c;它提供高数据采集速度&#xff0c;出色的兼容性&#xff0c…

模型部署工具01:Docker || 用Docker打包模型 Build Once Run Anywhere

Docker 是一个开源的容器化平台&#xff0c;可以让开发者和运维人员轻松构建、发布和运行应用程序。Docker 的核心概念是通过容器技术隔离应用及其依赖项&#xff0c;使得软件在不同的环境中运行时具有一致性。无论是开发环境、测试环境&#xff0c;还是生产环境&#xff0c;Do…

二、点灯基础实验

嵌入式基础实验第一个就是点灯&#xff0c;地位相当于编程界的hello world。 如下为LED原理图&#xff0c;要让相应LED发光&#xff0c;需要给I/O口设置输出引脚&#xff0c;低电平&#xff0c;二极管才会导通 2.1 打开初始工程&#xff0c;编写代码 以下会实现BLINKY常亮&…

推荐一个开源的轻量级任务调度器!TaskScheduler!

大家好&#xff0c;我是麦鸽。 这次推荐一款轻量级的嵌入式任务调度器&#xff0c;目前已经有1.4K的star&#xff0c;这个项目比较轻量化&#xff0c;只有5个源文件&#xff0c;可以作为学习的一个开源项目。 核心文件 项目概述&#xff1a; 这是一个轻量级的协作式多任务处理&…

【Vim Masterclass 笔记21】S09L39:Vim 设置与 vimrc 文件的用法示例(二)

文章目录 S09L39 Vim Settings and the Vimrc File - Part 21 Vim 的配色方案与 color 命令2 map 命令3 示例&#xff1a;用 map 命令快速生成 HTML 代码片段4 Vim 中的 Leader 键5 用 mkvimrc 命令自动生成配置文件 写在前面 本篇为 Vim 自定义配置的第二部分。当中的每个知识…

StarRocks 怎么让特定的SQL路由到FE master节点的

背景 本文基于 StarRocks 3.1.7 大家都知道对于Starrocks来说 FE 是分 master和follower的&#xff0c;而只有master节点才能对元数据进行写操作。但是为什么呢&#xff1f;哪里有体现呢&#xff1f; 这其中的原因在网上是搜不到的&#xff0c;所以大家只知道只有master节点才…