Maven的仓库和settings.xml配置文件

(尊重劳动成果,转载请注明出处:https://blog.csdn.net/qq_25827845/article/details/83549846冷血之心的博客)

关注微信公众号(文强的技术小屋),学习更多技术知识,一起遨游知识海洋~

快速导航:

Maven基础概念和安装配置教程

Maven的仓库和settings.xml配置文件

Maven的坐标与依赖

Maven的生命周期和插件

Maven的聚合与继承

 

目录

Maven的仓库

本地仓库

远程仓库

私服

中央仓库

settings.xml配置文件

总结


       在Maven基础概念和安装配置一文中,我们简单学习了Maven是什么,安装包里边的各个文件夹都存放着哪些东西,并且进行了简单的安装配置。在本文中,我们将进一步学习了解何为Maven仓库以及Maven的配置文件settings.xml如何配置。

 

Maven的仓库

       Maven用来存储依赖和插件的一个统一的地方,称之为仓库,Maven仓库又分为本地仓库和远程仓库。远程仓库又分为私服和中央仓库等。

 我们以一幅图来表示它们的关系:

本地仓库

       就是maven在本地(我们的计算机上)存储构件(依赖的Jar包等)的仓库,默认是在用户的.m2/repository/目录下。需要注意的是刚开始在.m2/下边是没有这个repository/文件夹的,当我们在命令行中运行mvn命令后才会出现该文件夹,并且在该文件夹下存储我们从远程仓库下载的构件。

既然Maven默认在/.m2/repository/下存储依赖和构件,那么我们是不是可以改变自定义这个位置?

答案是肯定的,注意看图中的/.m2/settings.xml 该文件是maven的配置文件,我们可以在该文件中通过标签<localRepository></localRepository>来配置本地仓库的位置。(settings.xml文件是啥?其作用是啥?我们需要如何配置将在下边详细讲解)

远程仓库

      远程仓库又分为中央仓库私服以及其它公共库,我们也借用一幅图来阐述它们之间的关系。

由图中可以看出,我们Maven用户是在和私服打交道,包括上传和下载构件,当私服满足不了我们的下载构件需求时,私服会和中央仓库或者其余公共仓库交互,将用户需要的构件缓存在私服仓库中。那么何为私服?

私服

       私服是一种特殊的远程仓库,它是架设在局域网内的仓库服务,私服代理广域网上的远程仓库,供局域网内的Maven用户使用。

局域网使用搭建maven私服的好处

1.节省外网带宽:减少重复请求造成的外网带宽消耗,将大部分构件缓存在私服,用户和私服的交互走局域网。

2.加速Maven构件:如果项目配置了很多外部远程仓库的时候,构建速度就会大大降低,因为外网下载速度很慢。

3.部署第三方构件:有些构件无法从外部仓库获得的时候,可以把这些构件部署到内部仓库(私服)中,供内部maven项目使用。

4.提高稳定性:避免当外网不稳定的时候,maven构建也变的不稳定的情况。

5.增强控制:在公司内部可以访问私服可以通过配置用户名和密码来增强权限控制。

5.降低中央仓库的负荷:maven中央仓库被请求的数量是巨大的,配置私服也可以大大降低中央仓库的压力

 

中央仓库

       Maven提供了一个中央仓库,其地址为:http://repo.maven.apache.org/maven2 ,该仓库包含了绝大多数流行的开源Java构件,以及源码、作者信息、SCM、信息、许可证信息等。据统计,每个月中央仓库大概会接受全世界Java程序员大概1亿次访问,其重要性不言而喻。

       在上一节Maven基础概念和安装配置教程 中,我们提到了maven的超级pom也是一种约定,所有的maven项目的pom文件都继承于该超级pom。(超级pom文件位于你的安装目录/apache-maven-3.2.5/lib/maven-model-builder-3.2.5.jar包中,并且在org/apache/maven/model/pom-4.0.0.xml路径下)在超级Pom中,对于中央仓库进行了配置,如下所示:

注意看该配置中的标签<snapshots></snapshots>,该标签设置为false,表示我们不从该仓库中获取不稳定的SNAPSHOT版本的构件;其实还有一个<releases></releases>标签,表示我们是否从该仓库中获取稳定版本的构件;

一段比较完整的远程仓库的配置如下:

<repositories>  
        <repository>  
            <id>jboss</id>  
            <name>JBoss Repository</name>  
            <url>http://repository.jboss.com/maven2/</url>  
            <releases>  
                <updatePolicy>daily</updatePolicy><!-- never,always,interval n -->  
                <enabled>true</enabled>  
                <checksumPolicy>warn</checksumPolicy><!-- fail,ignore -->  
            </releases>  
            <snapshots>  
                <enabled>false</enabled>  
            </snapshots>  
            <layout>default</layout>  
        </repository>  
</repositories>

<updatePolicy></updatePolicy>标签:表示Maven从远程仓库检查更新的频率, 默认值是daily ,表示每天都检查一次;never-从不检查;always-每次构建都检查更新;interval n-每隔n分支检查一次更新。

<checksumPolicy></checksumPolicy>标签:表示maven检查和检验文件的策略,warn为默认值,还可以选择ignore和fail,表示当maven检查检验和文件失败之后应该采取的行动。

既然我们配置了远程仓库,那么是不是也需要在某个地方进行远程仓库的权限认证?否则谁都可以下载上传构件岂不是一件很麻烦的事?

答案当然也是肯定的,我们需要远程仓库的权限认证。我们可以在settings.xml配置文件中配置<servers></servers>来搞定

<servers>
    <server>
      <id>archiva.internal</id>  // release版本的用户名和密码
      <username>admin</username>
      <password>pwdpwd</password>
    </server>
    <server>
      <id>archiva.snapshots</id> // snapshot版本的用户名和密码
      <username>admin</username>
      <password>pwdpwd</password>
    </server>
  </servers>

需要注意的是:这里的<id>archiva.snapshots</id>必须与POM中需要认证的repository元素的Id一致,这样maven才能知道我们的用户名和密码是在认证哪个仓库。

配置了远程仓库并且进行了仓库的权限认证,maven已经可以帮助我们自动下载所需的构件了,当我们准备把自己的构件上传到远程仓库供别人使用时,我们还需要使用<distributionManagement></distributionManagement>来搞定。

<distributionManagement>
        <repository>
            <id>archiva.internal</id>
            <name>Internal Release Repository</name>
            <url>http://nexus.d.xxx.net/nexus/content/repositories/releases/</url>
        </repository>
        <snapshotRepository>
            <id>archiva.snapshots</id>
            <name>Internal Snapshot Repository</name>
            <url>http://nexus.d.xxx.net/nexus/content/repositories/snapshots/</url>
        </snapshotRepository>
</distributionManagement>

配置了之后,我们可以通过mvn deploy将本地的构件发布到远程仓库中。

 

settings.xml配置文件

       当我们下载安装好Maven时,在其安装目录的conf下存在一个settings.xml的配置文件,这是一个全局的maven配置文件,为了不影响这台计算机上的其他用户,一般选择将该文件copy~/.m2/下边,作为一个用户层面的配置文件。

settings.xml文件中主要包含以下的元素:

localRepository本地仓库的目录。默认是用户目录下面的.m2/repository目录。

interactiveMode:表示是否使用交互模式,默认是true;如果设为false,那么当Maven需要用户进行输入的时候,它会使用一个默认值。

offline:表示是否离线,默认是false。这个属性表示在Maven进行项目编译和部署等操作时是否允许Maven进行联网来下载所需要的信息。

mirrors定义一系列的远程仓库的镜像,用于缓解远程仓库的压力。

profiles用于指定一系列的profile

activeProfiles:指定当前正在活跃的profile。

servers表示当需要连接到一个远程服务器的时候需要使用到的验证方式

接下来我们给出一个settings.xml的简单的配置文件示例:

<?xml version="1.0" encoding="UTF-8"?>
<settings>
  <mirrors>
    <mirror>
      <!--This sends everything else to /public -->
      <id>nexus</id>  // 镜像id
      <mirrorOf>*</mirrorOf>   // 表示代理所有仓库
      <url>http://nexus.d.xxx.net/nexus/content/groups/public</url>  // 该镜像的地址
    </mirror>
  </mirrors>
  <profiles>
    <profile>
      <id>development</id>
      <repositories> // 构件的仓库
        <repository>
          <id>central</id>
          <url>http://nexus</url>
          <releases><enabled>true</enabled></releases>
          <snapshots><enabled>true</enabled></snapshots>
        </repository>
      </repositories>
     <pluginRepositories> // 插件的仓库
        <pluginRepository>
          <id>central</id>
          <url>http://nexus</url>
          <releases><enabled>true</enabled></releases>
          <snapshots><enabled>true</enabled></snapshots>
        </pluginRepository>
      </pluginRepositories>
    </profile>
  </profiles>
  <activeProfiles>
    <activeProfile>development</activeProfile> // 对于所有的pom,上边定义的id=development的profile都是活跃状态的
  </activeProfiles>

  <servers>
    <server>
      <id>archiva.internal</id>  // release版本的用户名和密码
      <username>yangwenqiang</username>
      <password>pwdpwd</password>
    </server>
    <server>
      <id>archiva.snapshots</id> // snapshot版本的用户名和密码
      <username>yangwenqiang</username>
      <password>pwdpwd</password>
    </server>
  </servers>
</settings>

下边我们重点说两个比较有用的配置:

<mirrors></mirrors>:镜像,如果仓库X可以提供仓库Y存储的所有内容,那么就可以认为X是Y的一个镜像。说白了,任何一个可以从仓库Y获得的构件,都能够从它的镜像中获取。在上边的示例中,我们使用<url></url>中配置的http://nexus.d.xxx.net/nexus/content/groups/public来代理所有的远程仓库,其实这个代理一般情况下是你们公司的内网搭建的私服,在局域网内,加快访问速度等作用。

profiles: 可以配置构件和插件的远程仓库,并且可以通过<id>来配置多个profile,最后通过<activeProfiles>来指定当前处于活跃状态(即有效的)的profile配置是哪一个。

 

总结

        这篇文章我们简单了解了maven的仓库,以及如何配置远程仓库,包括私服镜像和远程仓库的认证等知识点。当我们真正入职某一家公司的时候,我想很重要的一件事就是对着身边的一个哥们说:“Hi,老哥,把你的settings文件给我一份呗

 

如果对你有帮助,记得点赞哦~欢迎大家关注我的博客,可以进群366533258一起交流学习哦~

本群给大家提供一个学习交流的平台,内设菜鸟Java管理员一枚、精通算法的金牌讲师一枚、Android管理员一枚、蓝牙BlueTooth管理员一枚、Web前端管理一枚以及C#管理一枚。欢迎大家进来交流技术。
 

关注微信公众号(文强的技术小屋),学习更多技术知识,一起遨游知识海洋~

 

评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

温柔狠角色

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值