一个大型软件应用程序通常由多个模块组成,这是多个团队在同一应用程序的不同模块上工作的常见情形。例如,考虑一个团队正在将应用程序的前端作为app- ui项目(app-ui.jar:1.0)并且他们正在使用数据服务项目(data-service.jar:1.0)。

现在可能发生的事情是,处理数据服务的团队正在快速修复或增强功能,他们几乎每隔一天都会将库发布到远程存储库。

现在,如果数据服务团队每隔一天上传一个新版本,则会出现以下问题 -

  • 数据服务团队每次发布更新的代码时都应该告诉app-ui团队。

  • app-ui团队需要定期更新他们的pom.xml以获取更新版本。

为了处理这种情况, SNAPSHOT 概念发挥作用。

什么是SNAPSHOT?

SNAPSHOT是指示当前开发副本的特殊版本。与常规版本不同,Maven会在每个版本的远程存储库中检查新的SNAPSHOT版本。

现在数据服务团队将每次发布SNAPSHOT的更新代码到数据库中,例如数据服务:1.0-SNAPSHOT,替换旧的SNAPSHOT jar。

快照vs版本

在版本的情况下,如果Maven曾经下载过所提到的版本,比如说data- service:1.0,它永远不会尝试下载版本库中的新版本1.0。要下载更新的代码,数据服务版本将升级到1.1。

在SNAPSHOT的情况下,每次app-ui团队构建项目时,Maven都会自动获取最新的SNAPSHOT(数据服务:1.0-SNAPSHOT)。

app-ui pom.xml

app-ui 项目正在使用1.0-SNAPSHOT的数据服务。

<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>app-ui</groupId>
   <artifactId>app-ui</artifactId>
   <version>1.0</version>
   <packaging>jar</packaging>
   <name>health</name>
   <url>http://maven.apache.org</url>
   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
   </properties>
   <dependencies>
      <dependency>
      <groupId>data-service</groupId>
         <artifactId>data-service</artifactId>
         <version>1.0-SNAPSHOT</version>
         <scope>test</scope>
      </dependency>
   </dependencies>
</project>

数据服务pom.xml

数据服务 项目正在发布1.0-SNAPSHOT用于每一次小的更改。

<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>data-service</groupId>
   <artifactId>data-service</artifactId>
   <version>1.0-SNAPSHOT</version>
   <packaging>jar</packaging>
   <name>health</name>
   <url>http://maven.apache.org</url>
   <properties>
      <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
   </properties>
</project>

尽管在SNAPSHOT的情况下,Maven每天都会自动获取最新的SNAPSHOT,但您可以使用- U切换到任何maven命令来强制maven下载最新的快照构建。

mvn clean package -U

让我们打开命令控制台,进入 C:\ > MVN> app-ui目录并执行以下 mvn 命令。

C:\MVN\app-ui>mvn clean package -U

Maven将在下载最新的SNAPSHOT数据服务后开始构建项目。

[INFO] Scanning for projects...
[INFO]--------------------------------------------
[INFO] Building consumerBanking
[INFO]    task-segment: [clean, package]
[INFO]--------------------------------------------
[INFO] Downloading data-service:1.0-SNAPSHOT
[INFO] 290K downloaded.
[INFO] [clean:clean {execution: default-clean}]
[INFO] Deleting directory C:\MVN\app-ui\target
[INFO] [resources:resources {execution: default-resources}]

[WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources,
i.e. build is platform dependent!

[INFO] skip non existing resourceDirectory C:\MVN\app-ui\src\main\resources
[INFO] [compiler:compile {execution:default-compile}]
[INFO] Compiling 1 source file to C:\MVN\app-ui\target\classes
[INFO] [resources:testResources {execution: default-testResources}]

[WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources,
i.e. build is platform dependent!

[INFO] skip non existing resourceDirectory C:\MVN\app-ui\src\test\resources
[INFO] [compiler:testCompile {execution: default-testCompile}]
[INFO] Compiling 1 source file to C:\MVN\app-ui\target\test-classes
[INFO] [surefire:test {execution: default-test}]
[INFO] Surefire report directory: C:\MVN\app-ui\target\
surefire-reports

--------------------------------------------------
 T E S T S
--------------------------------------------------

Running com.companyname.bank.AppTest
Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 0.027 sec

Results :

Tests run: 1, Failures: 0, Errors: 0, Skipped: 0

[INFO] [jar:jar {execution: default-jar}]
[INFO] Building jar: C:\MVN\app-ui\target\
app-ui-1.0-SNAPSHOT.jar
[INFO]--------------------------------------------------------
[INFO] BUILD SUCCESSFUL
[INFO]--------------------------------------------------------
[INFO] Total time: 2 seconds
[INFO] Finished at: 2015-09-27T12:30:02+05:30
[INFO] Final Memory: 16M/89M
[INFO]------------------------------------------------------------------------