【Nexus】Maven从Nexus中下载jar包

简介: 【Nexus】Maven从Nexus中下载jar包

一、前言

已经在nexus中创建了Maven私服,如果没有创建,可以借鉴此博客:【Nexus】Nexus创建Maven私服

确保托管资源库中已经有需要拉取的jar包,如果没有,可以借鉴此博客进行上传jar包:【Nexus】上传jar包至Nexus的两种方式

二、配置Apache Maven

配置Apache Maven的目的是为了使用仓库管理,而不是默认使用中央仓库

1、在Maven的settings.xml中添加一个镜像配置,并覆盖中央仓库的默认配置

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<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">
  <!-- 本地仓库地址 -->
  <localRepository>D:\workSoftware\Java\maven\repository</localRepository>
  <!--nexus服务器-->
  <servers>
    <!--id为对应资源库id-->
    <server>
      <id>tfjy-snapshot-hosted</id>
      <username>admin</username>
      <password>nexusb-test</password>
    </server>
    <server>
      <id>tfjy-hosted</id>
      <username>admin</username>
      <password>nexusb-test</password>
    </server>
    <server>
      <id>nexus</id>
      <username>admin</username>
      <password>nexusb-test</password>
    </server>
  </servers>
  <!--组资源库的url地址  id和name自定义,mirrorOf的值设置为central-->
  <mirrors>
    <mirror>
      <id>nexus</id>
      <name>nexus repository</name>
      <url>http://IP或域名:8089/repository/tfjy-group/</url>
      <mirrorOf>central</mirrorOf>
    </mirror>
  </mirrors>
</settings>

二、创建Maven项目,配置pom文件拉取Nexus中的jar包

1、确定配置的Maven的settings.xml是否是上一步修改的settings.xml文件,以及repository的路径

2、在pom文件中添加要使用的jar包依赖

①、在Nexus的托管仓库中查看需要拉取jar包的坐标,注意组资源库中能够查看所有托管资源库和代理资源库中的jar包

3、在pom.xml文件中引入jar包坐标,并且在添加一个本地repository中没有下载过jar包

①、jar包坐标

<dependency>
  <groupId>com.tfjybj</groupId>
  <artifactId>metaverse-demo</artifactId>
  <version>1.0-20230322.074428-1</version>
  <type>pom</type>
</dependency>

②、添加完依赖后的pom.xml结构

<?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.tfjybj</groupId>
    <artifactId>metaverse-common</artifactId>
    <version>1.0-SNAPSHOT</version>
    <properties>
        <maven.compiler.source>11</maven.compiler.source>
        <maven.compiler.target>11</maven.compiler.target>
    </properties>
    <dependencies>
        <dependency>
            <groupId>com.tfjybj</groupId>
            <artifactId>metaverse-demo</artifactId>
            <version>1.0-20230322.074428-1</version>
            <type>pom</type>
        </dependency>
    </dependencies>
</project>

4、重载Maven项目之后发现,pom.xml文件中对应的依赖不在冒红,并且在Dependencies已经有对应依赖

三、引入依赖时,加载Maven显示无法解析或找不到该jar包

1、当我们把需要引入的jar包下载下来时,加载maven项目后,显示Cannot resolve XXXXXX,其原因是:我们上传jar包时的路径是snapshot快照库,但maven无法下载snapshot快照库

2、maven的依赖管理方式

maven的依赖管理方式中将依赖分为两种版本,一种是Release正式版本,一种时Snapshot快照版本。一般版本号后面带有RELEASE或者什么都没有的就是正式版本,而版本号后面带有SNAPSHOT的则是快照版本

Maven对这两版本的依赖管理方式是不同的:

1、如果是正式版本的依赖,Maven在构建工程的时候会减产本地仓库有没有这个依赖,没有的话就去远程仓库拉取。因为是优先从本地仓库找,所以如果对该依赖做了迭代更新,需要重新发布一个正式版本,所以正式版本的依赖一般是一个稳定的版本。然而组间开发引用的其他组的依赖一直在频繁迭代更新,这就不能一直发正式版本了,需要用到Snapshot快照版本。

2、如果依赖是一个快照版本,Maven在构建工程的时候会优先检查远程仓库中的该快照版本是否有更新,如果有更新的话就下载到本地,这样就不用一直发版本了。

3、Maven默认是不开启Snapshot版本拉取的,需要配置开启

3、Maven开启Snapshot版本拉取jar包

①、在pom.xml中配置项目级的

<repositories>
  <repository>
    <id>nexus</id>
    <url>http://IP或域名:8089/repository/tfjy-group/</url>
    <releases>
      <enabled>true</enabled>
      <updatePolicy>always</updatePolicy>
    </releases>
    <snapshots>
      <enabled>true</enabled>
      <updatePolicy>always</updatePolicy>
    </snapshots>
  </repository>
</repositories>

②、在settings.xml中配置全局级的

<profiles>
  <profile>
    <id>roncoo-profile</id>
    <repositories>
      <repository>
        <id>nexus</id>
        <url>http://IP或域名:8081/nexus/content/groups/public/</url>
        <releases>
          <enabled>true</enabled>
        </releases>
        <snapshots>
          <enabled>true</enabled>
        </snapshots>
      </repository>
    </repositories>
  </profile>
</profiles>
<activeProfiles>
  <activeProfile>roncoo-profile</activeProfile>
</activeProfiles>


相关文章
|
3月前
|
Java Maven
2022最新版超详细的Maven下载配置教程、IDEA中集成maven(包含图解过程)、以及导入项目时jar包下载不成功的问题解决
这篇文章是一份关于Maven的安装和配置指南,包括下载、环境变量设置、配置文件修改、IDEA集成Maven以及解决jar包下载问题的方法。
2022最新版超详细的Maven下载配置教程、IDEA中集成maven(包含图解过程)、以及导入项目时jar包下载不成功的问题解决
|
3月前
|
敏捷开发 Java 测试技术
阿里云云效产品使用合集之如何下载流水线构建过程中生成的jar
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
3月前
|
Java Maven 容器
java依赖冲突解决问题之Maven在编译打包过程中对依赖的jar包如何解决
java依赖冲突解决问题之Maven在编译打包过程中对依赖的jar包如何解决
|
3月前
|
敏捷开发 Java 持续交付
阿里云云效产品使用合集之maven仓库是否可以代替自建的Nexus
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。
|
3月前
|
Java Maven 容器
Maven使用IDEA自带工具打包,同时将lib下的jar包打入,双击jar包可直接运行
使用IntelliJ IDEA的Artifacts功能,可以将项目依赖的第三方jar包打包进jar文件中,实现双击jar包即可直接运行。
Maven使用IDEA自带工具打包,同时将lib下的jar包打入,双击jar包可直接运行
|
3月前
|
SQL 前端开发 Java
在IDEA中使用Maven将SpringBoot项目打成jar包、同时运行打成的jar包(前后端项目分离)
这篇文章介绍了如何在IntelliJ IDEA中使用Maven将Spring Boot项目打包成可运行的jar包,并提供了运行jar包的方法。同时,还讨论了如何解决jar包冲突问题,并提供了在IDEA中同时启动Vue前端项目和Spring Boot后端项目的步骤。
在IDEA中使用Maven将SpringBoot项目打成jar包、同时运行打成的jar包(前后端项目分离)
|
3月前
|
Java jenkins 持续交付
jenkins学习笔记之十七:使用插件及maven上传制品到nexus
jenkins学习笔记之十七:使用插件及maven上传制品到nexus
|
4月前
|
Java
[JarEditor]可直接修改jar包的IDEA插件
### 修改JAR包变得更简单:JarEditor插件简介 **背景:** 开发中常需修改JAR包中的class文件,传统方法耗时费力。JarEditor插件让你一键编辑JAR包内文件,无需解压。 **插件使用:** 1. **安装:** 在IDEA插件市场搜索JarEditor并安装。 2. **修改class:** 打开JAR文件中的class,直接编辑,保存后一键构建更新JAR。 3. **文件管理:** 右键菜单支持在JAR内新增/删除/重命名文件等操作。 4. **搜索:** 使用内置搜索功能快速定位JAR包内的字符串。
437 2
[JarEditor]可直接修改jar包的IDEA插件
|
4月前
|
弹性计算 Java Serverless
Serverless 应用引擎操作报错合集之上传自定义JAR包,启动时报错,是什么导致的
Serverless 应用引擎(SAE)是阿里云提供的Serverless PaaS平台,支持Spring Cloud、Dubbo、HSF等主流微服务框架,简化应用的部署、运维和弹性伸缩。在使用SAE过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
4月前
|
关系型数据库 Java 分布式数据库
PolarDB产品使用问题之部署到服务器上的Java应用(以jar包形式运行)无法连接,如何解决
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。

推荐镜像

更多