maven私服仓库之nexu使用

    前边简单介绍了Maven,Maven默认提供的中央仓库是在远程网络服务Appache提供的,这对于我们开发时不合理的。如果我们没网了或者什么情况,我们怎么办?也就是说我们队中央仓库的依赖性太大。而Nexus私服则可以解决我们这个问题。先看下这张图应该大家就非才明白了:




    这样就相当于在我们本地的局域网搭建了一个类似中央仓库的服务器,我们开始将中央仓库的一些资料下载到私服务器上,然后平时我们的maven项目就是直接访问局域网内的私服即可,既节省了网络带宽也会加速项目搭建的进程,这样对我们开发来说,对公司来说都是非常好的选择。下边简单看一下Nexus私服的简单使用:


    1、Nexus下载

    下载地址:http://www.sonatype.org/nexus/go

 

    2、Nexus启动

    我下载的是zip包,解压后进入\nexus-2.1.2-bundle\nexus-2.1.2\bin\jsw\,根据操作系统类型选择文件夹,我选的是windows-x86-32文件夹,进入后可看到如下所示bat文件。




    双击console-nexus.bat运行。游览器中输入http://127.0.0.1:8081/nexus/,出现如下图所示就代表nexus已经启动成功。


    8081为默认的端口号,要修改端口号可进入nexus-2.1.2-bundle\nexus-2.1.2\conf\打开nexus.properties文件,修改application-port属性值就可以了。

 

    默认的用户名和密码:admin/admin123,登录后看到如下图所示:


    3、Nexus仓库

    nexus的仓库类型分为以下四种:

              group: 仓库组

              hosted:宿主

             proxy:代理

             virtual:虚拟

   首次登陆nexus后可以看到以下一个仓库组和多个仓库。


    PublicRepositories:  仓库组

                  3rd party: 无法从公共仓库获得的第三方发布版本的构件仓库

                  Apache Snapshots: 用了代理ApacheMaven仓库快照版本的构件仓库

                  Central: 用来代理maven中央仓库中发布版本构件的仓库

                  Central M1 shadow: 用于提供中央仓库中M1格式的发布版本的构件镜像仓库

                  Codehaus Snapshots: 用来代理CodehausMaven 仓库的快照版本构件的仓库

                  Releases: 用来部署管理内部的发布版本构件的宿主类型仓库

                 Snapshots:用来部署管理内部的快照版本构件的宿主类型仓库

    4、配置nexus

 

    4.1、开启远程索引

    新搭建的neuxs环境只是一个空的仓库,需要手动和远程中心库进行同步,nexus默认是关闭远程索引下载,最重要的一件事情就是开启远程索引下载。登陆nexus系统,默认用户名密码为admin/admin123。

点击左边Administration菜单下面的Repositories,找到右边仓库列表中的三个仓库Apache Snapshots,Codehaus Snapshots和Maven Central,然后再没有仓库的configuration下把Download Remote Indexes修改为true。如下图


    然后在Apache Snapshots,Codehaus Snapshots和Maven Central这三个仓库上分别右键,选择Repari Index,这样Nexus就会去下载远程的索引文件。


    这样设置以后, Nexus会自动从远程中央仓库下载索引文件, 为了检验索引文件自动下载是否生效,可以却换到Browse Index


    在左边菜单栏里面有个Artifact Search, 在输入框里面输入你想要搜索的构件名字,比如:maven, 那么查询结果如下:


    4.2建立宿主仓库

    新 建公司的内部仓库,步骤为Repositories –> Add –>Hosted Repository,在页面的下半部分输入框中填入Repository ID和Repository Name即可,比如分别填入zfy 和 zfy repostiory,另外把Deployment Policy设置为Allow Redeploy,点击save就创建完成了。

这里我点击添加宿主类型的仓库,在仓库列表的下方会出现新增仓库的配置,如下所示:




    点击save按钮后就会在仓库列表中看到刚才新增的仓库。

 

 

    4.3、创建Nexus仓库组

    Nexus 中仓库组的概念是Maven没有的,在Maven看来,不管你是hosted也好,proxy也好,或者group也好,对我都是一样的,我只管根据 groupId,artifactId,version等信息向你要构件。为了方便Maven的配置,Nexus能够将多个仓库,hosted或者 proxy合并成一个group,这样,Maven只需要依赖于一个group,便能使用所有该group包含的仓库的内容。

    neuxs- 1.9.2.3中默认自带了一个名为“Public Repositories”组,点击该组可以对他保护的仓库进行调整,把刚才建立的公司内部仓库zfy repostiory加入其中,这样就不需要再在maven中明确指定内部仓库 的地址了。同时创建一个Group ID为public-snapshots、Group Name为Public SnapshotsRepositories的组,把Apache Snapshots、Codehaus Snapshots、Snapshots和zfy repostiory加入其中。






    到这里neuxs的安装配置就完成了,下面介绍如何在maven中使用自己的私服。

 

 

 

    4.4、创建Nexus代理仓库

    点击菜单栏上的Add按钮后选择Proxy Repository,看到如下所示配置界面:


    5、settings.xml的配置

  1.     <?xml version="1.0" encoding="UTF-8"?>    
  2.   <settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"     
  3.           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"     
  4.           xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">    
  5.     
  6.    <pluginGroups></pluginGroups>    
  7.     <proxies></proxies>    
  8.    
  9.    <servers>    
  10.      <server>    
  11.       <id>nexus-releases</id>    
  12.       <username>admin</username>    
  13.        <password>admin123</password>    
  14.     </server>    
  15.     <server>    
  16.      <id>nexus-snapshots</id>    
  17.       <username>admin</username>    
  18.       <password>admin123</password>    
  19.      </server>    
  20.   </servers>    
  21.     
  22.   <mirrors>     
  23.      <mirror>     
  24.        <id>nexus-releases</id>     
  25.        <mirrorOf>*</mirrorOf>     
  26.        <url>http://localhost:8081/nexus/content/groups/public</url>     
  27.      </mirror>    
  28.      <mirror>     
  29.        <id>nexus-snapshots</id>     
  30.       <mirrorOf>*</mirrorOf>     
  31.        <url>http://localhost:8081/nexus/content/groups/public-snapshots</url>     
  32.      </mirror>     
  33.    </mirrors>     
  34.     
  35.    <profiles>    
  36.     <profile>    
  37.       <id>nexus</id>    
  38.       <repositories>    
  39.         <repository>    
  40.          <id>nexus-releases</id>    
  41.            <url>http://nexus-releases</url>    
  42.            <releases><enabled>true</enabled></releases>    
  43.            <snapshots><enabled>true</enabled></snapshots>    
  44.          </repository>    
  45.          <repository>    
  46.          <id>nexus-snapshots</id>    
  47.           <url>http://nexus-snapshots</url>    
  48.           <releases><enabled>true</enabled></releases>    
  49.            <snapshots><enabled>true</enabled></snapshots>    
  50.          </repository>    
  51.        </repositories>    
  52.        <pluginRepositories>    
  53.          <pluginRepository>    
  54.                 <id>nexus-releases</id>    
  55.                   <url>http://nexus-releases</url>    
  56.                   <releases><enabled>true</enabled></releases>    
  57.                   <snapshots><enabled>true</enabled></snapshots>    
  58.                 </pluginRepository>    
  59.                 <pluginRepository>    
  60.                   <id>nexus-snapshots</id>    
  61.                    <url>http://nexus-snapshots</url>    
  62.                  <releases><enabled>true</enabled></releases>    
  63.                   <snapshots><enabled>true</enabled></snapshots>    
  64.               </pluginRepository>    
  65.           </pluginRepositories>    
  66.      </profile>    
  67.    </profiles>    
  68.     
  69.    <activeProfiles>    
  70.        <activeProfile>nexus</activeProfile>    
  71.    </activeProfiles>    
  72.    
  73.  </settings>    
  74. </span>  

    6 maven 项目 pom.xml配置 


  1.     <pre class="html" name="code"> <distributionManagement>    
  2.          <!-- 两个ID必须与 setting.xml中的<server><id>nexus-releases</id></server>保持一致-->    
  3.          <repository>    
  4.               <id>nexus-releases</id>    
  5.               <name>Nexus Release Repository</name>    
  6.             <url>http://localhost:8081/nexus/content/repositories/releases</url>    
  7.           </repository>    
  8.           <snapshotRepository>    
  9.               <id>nexus-snapshots</id>    
  10.              <name>Nexus Snapshot Repository</name>    
  11.              <url>http://localhost:8081/nexus/content/repositories/snapshots</url>    
  12.          </snapshotRepository>    
  13.      </distributionManagement></pre><pre class="html" name="code"> </pre><pre class="html" name="code"></pre><pre class="html" name="code"><img alt="" src="https://img-my.csdn.net/uploads/201301/10/1357787083_3866.png"><img alt="" src="https://img-my.csdn.net/uploads/201301/10/1357787109_8992.png"></pre><pre class="html" name="code"> </pre>    
  14. 14. <pre></pre>    
  15. 15. <pre></pre>    
  16. </span>  
项目运行 mvn:deploy命令发布包,会发现下载路径必不是中央库的路径,而是nexus里面的仓库组路径。这个说明配置环境成功。
转载出自 http://blog.csdn.net/liujiahan629629/article/details/39272321

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Maven是一款流行的项目构建工具,它可以帮助开发人员管理项目依赖和构建过程。在使用Maven构建项目时,我们可以通过配置仓库来获取项目所需的依赖。 仓库是一种由团队或组织自行维护的Maven仓库,用于存储项目的依赖库。相比于公共仓库仓库可以提供更快的下载速度和更可控的访问权限。 要从仓库获取依赖,首先需要在Maven的配置文件(settings.xml)中添加仓库的配置。在该文件中,可以配置多个仓库,每个仓库都有一个唯一的id和url地址。 当需要从仓库获取依赖时,只需要在项目的pom.xml文件中指定依赖的groupId、artifactId和版本号即可。Maven会根据这些信息,到配置的仓库中搜索对应的依赖,并自动下载到本地仓库。 在开发过程中,经常会遇到有依赖需要从仓库获取的情况。有依赖是指项目中自己开发的或者来自于组织内部的依赖,这些依赖无法在公共仓库中找到。通过配置仓库,我们可以将这些有依赖发布到仓库,并在其他项目中使用。 总的来说,通过配置仓库,我们可以更高效地获取项目所需的依赖,提高项目构建的速度和稳定性,同时也方便了团队内部的依赖共享。 ### 回答2: Maven是一个开源的构建工具,可用于自动化构建和依赖管理。在使用Maven构建项目时,可以从仓库获取依赖。 仓库是一种自建的Maven仓库,用于存储项目依赖和构建产物。相比于公共的中央仓库仓库可以提供更高的稳定性和可控性。 要从仓库获取依赖,首先需要在项目的pom.xml文件中配置仓库的地址。这可以通过在<repositories>标签内添加<repository>标签来完成。在<repository>标签中,需要设置仓库的唯一标识、URL、以及可选的认证信息。 配置好仓库后,Maven会自动检查项目所需的依赖是否在仓库中存在。如果存在,则会从仓库下载依赖到本地的仓库中。如果未找到依赖,Maven还会进一步检查其他配置的远程仓库,包括中央仓库和其他已配置的仓库仓库的配置也可以通过Maven的配置文件settings.xml进行全局配置。通过在settings.xml文件中配置<mirrors>标签,可以设置多个仓库,包括仓库的唯一标识、URL和认证信息。 总结来说,要从仓库获取依赖,需要在项目的pom.xml文件或Maven的配置文件settings.xml中配置仓库的地址和认证信息。配置完成后,Maven会自动检查并下载依赖到本地仓库中,以供项目构建使用。 ### 回答3: Maven是一个开源的项目管理和构建自动化工具,它使用仓库(Repository)来管理项目的依赖关系。通常情况下,Maven会从中央仓库(Central Repository)获取依赖项。 然而,在某些情况下,中央仓库中可能没有我们需要的特定依赖项,或者我们希望使用有的仓库来管理某些自定义的依赖项。这时,我们可以通过配置Maven来从仓库获取依赖项。 首先,我们需要在 Maven 的配置文件settings.xml中添加仓库的配置信息。settings.xml默认位于Maven的安装目录的conf文件夹中。我们可以打开该文件,在<settings>标签下找到<mirrors>标签,然后在<mirrors>标签内部添加的配置信息。例如: <settings> ... <mirrors> <mirror> <!-- ID,用于标识 --> <id>my-mirror</id> <!-- 的URL --> <url>http://my.private.repo</url> <!-- 是否在下载时跳过中央仓库,默认false --> <mirrorOf>central</mirrorOf> </mirror> </mirrors> ... </settings> 在这个配置中,我们为仓库指定了一个唯一的ID(my-mirror),并且设置了的URL(http://my.private.repo)。在<mirrorOf>标签中,我们可以指定需要从仓库获取的依赖项。在上面的例子中,我们将中央仓库(central)作为需要跳过的镜像。 保存并关闭settings.xml配置文件后,我们就可以使用Maven仓库获取依赖项了。当我们向项目的pom.xml文件中添加需要的依赖项时,Maven会自动检查并从仓库获取相关依赖。如果仓库中存在该依赖项,那么Maven会在构建过程中自动下载并使用该依赖项。 总之,通过配置Maven的settings.xml文件,我们可以轻松地从仓库获取项目所需的依赖项,确保项目的构建和管理更加灵活和可靠。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值