`
leonzhx
  • 浏览: 799540 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

第六章 仓库

阅读更多

1.   Maven 在一个工作站上的某个位置统一存储所有 Maven 项目共享的构件,这个统一的位置就是仓库。 Maven 项目将不再各自存储其依赖的文件,它们只需要声明这些依赖项目的坐标,在需要的时候, Maven 会自动在仓库中找到它们,并使用它们。一个 Maven 项目构建完毕后生成的构件也可以安装到仓库中供其它项目使用。

 

2.   一个构件在仓库中的路径为:

 

groupId/artifactId/baseVersion/artifactId-version(-classifier).packaging 。其中 groupId 中的“ . ”会被替换成路径分隔符“ / ”, baseVersion 主要是对应 SNAPSHOT version 而言的,如果一个构建的 version 1.0.0-SNAPSHOT ,那 baseVersion 就是 1.0.0 。例如:

org.testing:testing:2.5.6-SNAPSHOT:jdk5:jar 就会对应到

org/testing/testing/2.5.6/testing-2.5.6-SNAPSHOT-jdk5.jar

 

3.   Maven 仓库分为两类:本地仓库和远程仓库。当 Maven 寻找构件时会先查找本地仓库,如果本地仓库不存在此构件,或者需要查看是否有更新的构件版本, Maven 就会去远程仓库查找。

 

4.   一些公共远程仓库: Java.net Maven 库( http://download.java.net/maven/2 )和 JBoss Maven 库( http://repository.jboss.com/maven2/ )。

 

5.   Maven 默认的本地仓库位置是在用户目录下的 .m2/repository 下。也可以修改 .m2/settings.xml 自定义仓库位置:

 

<settings>
  <localRespository>D:\java\repository</localRepository>
</settings>  

 

6.     mvn clean install 可以将当前 Maven 项目构建出的构件安装到本地的仓库中。

 

7.   Maven 默认自带了一个中央仓库,解压 lib/ maven-model-builder-3.0.jar Maven2 中为 maven-2.2.1-uber.jar ),然后访问路径 org/apache/maven/model/pom-4.0.0.xml Maven2 中为 org/apache/maven/project/pom-4.0.0.xml ),可以看到:

 

<repositories>

  <repository>

    <id>central</id>

    <name>Maven Repository Switchboard</name>

    <url>http://repo1.maven.org/maven2 </url>

    <layout>default</layout>

    <snapshots>

      <enabled>false</enabled>

    </snapshots>

  </repository>

</repositories>

 

Maven1 layout legacy ,构件会有不同的文件路径。 snapshots enabled 设为 false 表明 Maven 不会从该远程仓库下载 SNAPSHOT 版本的构件。

 

 

8.   私服是一种特殊的远程仓库,它可以:

    1) 节省外网带宽。(构件缓存在局域网的私服上)

    2) 加速 Maven 构建。(构建时只需检查私服上的更新)

    3) 部署第三方构件。(有些构件因版权问题不能放在公共仓库上)

    4) 提高稳定性,增强控制( Internet 不稳定时不影响构建。 Nexus 有许多增强功能)

    5) 降低中央仓库的负荷

     

 

9.  可 以修改项目的 POM ,添加远程仓库的配置:

 

<repositories>

  <repository>

    <id>jboss</id>

    <name>JBoss Repository</name>

    <url>http://repository.jboss.com/maven2/</url >

    <releases>

        <enabled>true</enabled>

    </releases>

    <snapshots>

         <enabled>false</enabled>

    </snapshots>

    <layout>default</layout>

  </repository>

</repositories>
 

仓库的 id 必须是唯一的, Maven 自带的中央仓库的 id central ,如果 POM 中声明的仓库 id 也是 central 会覆盖中央仓库。 releases enabled true snapshots enabled false ,表明该仓库只会下载 release 版本不会下载 snapshot 版本。

 

 

10.  s napshots releases 中还可以包含 updatePolicy checksumPolicy 两个元素

updatePolicy 表示检查更新的周期,可选值为: daily (每天检查一次), never (从不检查), always (每次构建都检查), interval:X (每隔 X 分钟检查一次)。默认值为 daily

checksumPolicy 是用来表明校验失败时如何处理,可选值为 warn fail ignore 。默认值为 warn

 

11.   有些远程仓库需要认证,但认证信息不宜放在 POM 中,因为 POM 一般会被提交到代码仓库中,不安全。认证信息会被配置在 settings.xml 中:

 

<servers>

  <server>

    <id>jobs</id>

    <username>usrname</username>

    <password>passw0rd</password>

  </server>

</servers> 
 

id 要和仓库的 id 保持一致。

 

12.  可 以在 POM 中配置构件想要部署到的远程仓库的信息:

 

<distributionManagement>

  <repository>

    <id>proj-release</id>

    <name>Project Release Repository</name>

    <url>http://192.168.1.100/content/repositories/proj-releases</url>

  </repository>

  <snapshortRepository>

     <id>proj-snapshot</id>

    <name>Project Snapshot Repository</name>

    <url>http://192.168.1.100/content/repositories/proj-snapshots</url>

  </snapshotRepository>

</distributionManagement> 
 

repository 中配置的是项目稳定版本( release 版本)发布的仓库地址, snapshotRepository 中配置的是项目非稳定版本( snapshot 版本)发布的仓库地址。认证信息同样在 settings.xml 中的 servers 元素中配置。

 

13.   Mvn clean deploy 就会将项目构建输出的构件部署到对应的远程仓库中。

 

14.   POM 中的项目版本定义为快照版本时,如 2.1-SNAPSHOT Maven 在发布项目时会将 SNAPSHOT 替换成当前时间戳。如 2.1-20111203-174413-12 表示 2011 12 3 17 44 13 秒的第 12 次快照。而当 POM 中声明的依赖为 SNAPSHOT 版本时, Maven 会在远程仓库中寻找最新的快照。

 

15.   快照版本只应该在组织内部的项目或模块间依赖使用,而不应该依赖于组织外部的快照版本。因为快照版本是不稳定的,今天构建成功很可能明天就构建失败。

 

16.   依赖解析机制:

    1) 依赖为 system 时,直接从本地文件系统解析。

    2)在 本地仓库寻找构件,如果发现相应构件,则解析成功。

    3)在 本地仓库找不到构件时,到所有配置的远程仓库寻找构件。

 

17.   如果依赖的版本是 RELEASE (最新 release 版本)或者 LATEST (最新版本)。(这两者 Maven3 已经不支持,只有当不指定版本号时, Maven3 默认为最新 release 版本)则基于更新策略读取所有远程仓库的 groupId/artifactId/maven-metadata.xml 中的元数据和与本地仓库中的元数据合并后,计算出真实的版本号再解析。 Metadata 信息如下:

 

<?xml version=”1.0” encoding=”UTF-8”?>

<metadata>

  <groupId>org.sonatype.nexus</groupId>

  <artifactId>nexus</artifact>

  <versioning>

    <latest>1.4.2-SNAPSHOT</latest>

    <release>1.4.0</release>

    <versions>

      <version>1.3.5</version>

      <version>1.3.6</version>

       <version>1.4.0-SNAPSHOT</version>

      …

    </versions>

    <lastUpdated>20111203180918</lastUpdated>

  </versioning>

</metadata> 
 

18.   如果依赖的版本是 SNAPSHOT ,则基于更新策略读取所有远程仓库的 groupId/artifactId/version/maven-metadata.xml 中的元数据和与本地仓库中的元数据合并后,计算出最新的快照版本的值,再进行解析。 Metadata 信息如下:

 

<?xml version=”1.0” encoding=”UTF-8”?>

<metadata>

  <groupId>org.sonatype.nexus</groupId>

  <artifactId>nexus</artifactId>

  <version>1.4.2-SNAPSHOT</version>

  <versioning>

    <snapshot>

      <timestamp>20111203.181523</timestamp>

       <buildNumber>12</buildNumber>

    </snapshot>

    …

    <lastUpdated>20111203181620</lastUpdated>

  </versioning>

</metadata>  

 

19.   远程仓库的更新策略由远程仓库配置中( <repositories> 元素) <releases> <snapshots> 中配置的 <updatePolicy> 决定,用户也可以在命令行加入参数 -U 来强制更新, Maven 就会忽略 updatePolicy

 

20.   如果最后解析得到的构件版本是时间戳格式的快照,如 1.4.1-20091104.121450-121 ,则复制其时间戳格式的文件至非时间戳格式,如 SNAPSHOT ,并使用该非时间戳格式的构件。何解?为什么?

 

21.   如果所有可以从仓库 A 上获得的构件都可以从仓库 B 上获得,我们称仓库 B 为仓库 A 的镜像。可以修改 settings.xml 来配置远程仓库的镜像:

 

<mirrors>

  <mirror>

    <id>maven.net.cn</id>

    <name>one of the central mirrors in China</name>

    <url>http://maven.net.cn/content/groups/public/</url>

    <mirrorOf>central</mirrorOf>

  </mirror>

  …

</mirrors>  

mirrorOf 可以取以下几种特殊值:

   * ,所有远程仓库(通常私服为所有远程仓库的镜像)

   external:* ,所有非本机上的远程仓库(使用 localhost file:// 的除外)

   repo1,repo2 ,多个仓库用逗号分隔

   *, !repo1 ,所有远程仓库 repo1 除外。

 

22. 仓库搜索服务

    名字

网址

特殊功能

基本功能

Sonatype Nexus

http://repository.sonatype.org/

基于checksum 搜索

关键字搜索、类名搜索、坐标搜索
生成XML 依赖声明

Jarvana

http://www.jarvana.com/jarvana/

浏览构件内部的内容
便捷的Java 文档浏览

MVNbrowser

http://www.mvnbrowser.com/

显示某个构件依赖于哪些构件以及被哪些构件引用

MVNrepository

http://mvnrepository.com/

显示某个构件各版本间的大小变化,构件之间的依赖关系

  • 大小: 3.7 MB
分享到:
评论
1 楼 huiyibuzai 2012-07-01  
如果最后解析得到的构件版本是时间戳格式的快照,如 1.4.1-20091104.121450-121 ,则复制其时间戳格式的文件至非时间戳格式,如 SNAPSHOT ,并使用该非时间戳格式的构件。何解?为什么?

我理解的是这样的:
首先,我们的A项目版本为: 1.4.1-SNAPSHOT
通过我们的命令mvn -clean deploy部署到远程仓库后存放的版本为:1.4.1-20091104.121450-121
然后其他人在B项目中通过pom配置依赖A项目的构建版本:1.4.1-SNAPSHOT
这时需要去远程仓库拿该构建的最新快照版本(为1.4.1-20091104.121450-121),但因为我们项目中需要的版本号为:1.4.1-SNAPSHOT,所以最终使用的是该非时间戳格式的构件。这样可以保证我们使用的快照版本是远程仓库上最新的版本号

相关推荐

    泰格百货超市7.3

    第六章 仓库管理 第七章 财务管理 第八章 卖场管理 第九章 联营管理 第十章 总经理查询 第十一章 系统管理 第十二章 工资管理 第十三章 配送管理 第十四章 连锁分店业务管理 第十五章 二代机接口模块 第三...

    研究生第六章数据仓库与数据挖掘的决策支持.pptx

    研究生第六章数据仓库与数据挖掘的决策支持.pptx

    第三章仓库生产设备配置.pdf

    《第三章仓库生产设备配置》章节主要探讨了仓库设备配置的重要性、设备分类、特点以及选择原则。仓库设备配置是仓库系统规划的关键部分,不仅影响仓库的建设和运营成本,还直接关系到仓库的作业效率和经济效益。 ...

    第二章仓库规划与设置.pptx

    《第二章 仓库规划与设置》的PPT内容聚焦于仓库设计的重要环节,包括仓库的选址、储存布局、制造业仓库规划以及仓库总面积的确定。仓库规划是物流运作的关键部分,直接关乎企业的运营效率、成本控制和客户服务。 ...

    精品课件-数据仓库与数据挖掘PPT合集(共13章).zip

    第6章 序列模式挖掘.pptx 第7章 分类方法(续).pptx 第7章 分类方法.pptx 第8章 回归和时序分析.pptx 第9章 粗糙集理论.pptx 第10章 聚类方法(续).pptx 第10章 聚类方法.pptx 第11章 Web使用挖掘介绍及趋势.pptx

    数据库系统第六章答案

    在本资源中,我们聚焦于"数据库系统第六章答案",这是一个针对特定章节学习的辅助材料,旨在帮助学生理解和掌握数据库系统的深入概念,特别是与SQL Server相关的编程实践。 第六章通常涵盖数据库设计、查询优化、...

    数据仓库(原书中文第四版)

    第6章 分布式数据仓库 116 6.1 引言 116 6.2 局部数据仓库 118 6.3 全局数据仓库 119 6.4 互斥数据 121 6.5 冗余 123 6.6 全局数据存取 124 6.7 分布式环境下其他考虑因素 126 6.8 管理多个开发项目 127 6.9 开发...

    《数据仓库与数据挖掘》第9章.pptx

    《数据仓库与数据挖掘》第9章主要探讨了分类和预测这两个重要的数据分析技术。分类是预测离散或名义类别的过程,而预测则用于建模连续值函数,预测未知或缺失的值。这两种方法在各个领域都有广泛的应用,如信用审批...

    第6章-数据库和数据仓库技术.pptx

    第6章-数据库和数据仓库技术.pptx

    第02章 仓库管理系统

    6. **安全性**:设置合适的权限,防止未经授权的访问,保护敏感数据的安全。 通过学习和实践这个仓库管理系统,开发者不仅可以掌握数据库系统的开发技术,还能提升对软件工程的理解,包括需求分析、系统设计、编码...

    第九章仓库生产绩效管理PowerPointPrese.pptx

    第九章的仓库生产绩效管理是物流管理中的关键环节,它涉及到如何评估和改进仓库运营的效率和效果。绩效管理旨在确保仓库运作与企业目标相一致,通过设定和追踪一系列指标来提升生产力,降低成本,提高服务质量。 一...

    重庆大学BI课程 商业智能课程 商务智能课程 数据挖掘课程第3章 数据仓库(共155页).ppt

    第6章 分类算法基础-决策树(共103页).ppt 第6章 其他分类算法(共76页).ppt 第7章 聚类算法分析(共140页).ppt 第8章 应用案例分析(共10页).ppt 2016数据挖据教学计划.docx 期末考核.ppt

    数据仓库的原理与应用

    本书主要介绍数据仓库的概念、基本原理、规划、开发方法以及相关算法。全书共分7章。第1章介绍决策支持、数据仓库和数据开采技术的历史...第6章介绍数据开采的主要理论和方法,第7章介绍联机分析概念、技术和相关产品。

    第六章数据库与数据仓库--PZZ.pptx

    【第六章 数据库与数据仓库】的讲解涵盖了数据库技术的基础概念和数据管理的发展历程,以及数据仓库的相关内容。本章内容主要分为两大部分:数据库技术和数据仓库。 首先,讲解了数据库的基本概念。数据库是一个...

    仓库管理制度物资的储存保管

    第六条 不合格品应隔离堆放。 第七条 验收中发现的问题,要及时通知主管和经办人处理。托收单到而货未到,或货已到而无发票,均应向经办人反映查询,直至消除悬念挂账。 签发人 责任人签名 制度名 仓库管理制度...

    大数据分析与大数据挖掘课程 数据仓库与数据挖掘教程 第7章 聚类分析 共78页.pptx

    【课程简介】 本课程适合所有需要学习数据仓库与数据挖掘知识的同学,课件内容制作精细,由浅入深,适合入门...数据仓库与数据挖掘教程 第6章 关联挖掘 共30页.pptx 数据仓库与数据挖掘教程 第7章 聚类分析 共78页.pptx

    数据仓库(分章教材)

    第六章:数据仓库的演变与云计算 随着大数据和云计算的发展,数据仓库也面临着新的挑战和机遇。本章将介绍云数据仓库的概念,如Amazon Redshift、Google BigQuery和Microsoft Azure Synapse Analytics,并探讨它们的...

    数据仓库原理 数据仓库设计与应用 第2章 数据仓库开发模型(共30页).ppt

    数据仓库的开发模型分为六个主要部分:数据仓库开发模型、数据仓库概念模型、数据仓库逻辑模型、数据仓库的物理模型、数据仓库的元数据模型以及数据仓库的粒度和聚集模型。 首先,数据仓库开发模型是一种将现实世界...

    第2章_仓库选址规划布局.ppt

    本章主要探讨了仓库规模和数量的决策、仓库选址、选址方法以及平面规划等多个方面。 一、仓库规模的决策 仓库规模的确定基于产品产量、库存周转率、客户服务水平、市场大小、最大日库存量、库存物品尺寸、物料搬运...

Global site tag (gtag.js) - Google Analytics