为什么Maven每次都下载maven-metadata.xml?

时间:2013-05-07 14:21:26

标签: java maven maven-3 maven-metadata

以下是当我尝试使用maven构建Web应用程序时,我的互联网连接很常见的错误。

我的问题是,为什么每次在早期构建相同的应用程序时都必须下载maven。

我的配置中每次都能下载maven会出现什么问题?

以下是我尝试离线构建时遇到的错误:

[INFO] ------------------------------------------------------------------------
[INFO] Building mywebapp 1.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
Downloading: https://raw.github.com/pagecrumb/mungo/mvn-repo/com/pagecrumb/mungo/0.0.1-SNAPSHOT/maven-metadata.xml

[WARNING] Could not transfer metadata com.mywebapp:mungo:0.0.1-SNAPSHOT/maven-metadata.xml 
from/to mungo-mvn-repo (https://raw.github.com/pagecrumb/mungo/mvn-repo/): raw.github.com
[INFO] 
[INFO] --- maven-war-plugin:2.1.1:war (default-cli) @ mywebapp ---
[INFO] Packaging webapp
[INFO] Assembling webapp [mywebapp] in [D:\workspace\web\target\mywebapp-1.0-SNAPSHOT]
[INFO] Processing war project
[INFO] Copying webapp resources [D:\workspace\web\src\main\webapp]
[INFO] Webapp assembled in [1237 msecs]
[INFO] Building war: D:\workspace\web\target\mywebapp-1.0-SNAPSHOT.war
[WARNING] Warning: selected war files include a WEB-INF/web.xml which will be ignored 
(webxml attribute is missing from war task, 
or ignoreWebxml attribute is specified as 'true')
[INFO]                                                                         
[INFO] ------------------------------------------------------------------------
[INFO] Building com.mywebapp [com.mywebapp] 0.0.1-SNAPSHOT
[INFO] ------------------------------------------------------------------------
Downloading: http://repo.maven.apache.org/maven2/org/apache/maven/plugins/maven-release-plugin/2.1/maven-release-plugin-2.1.pom

[WARNING] Failed to retrieve plugin descriptor for org.apache.maven.plugins:maven-release-plugin:2.1: Plugin org.apache.maven.plugins:maven-release-plugin:2.1 or one of its dependencies could not be resolved: Failed to read artifact descriptor for org.apache.maven.plugins:maven-release-plugin:jar:2.1
Downloading: http://download.java.net/maven/2/org/apache/maven/plugins/maven-metadata.xml
Downloading: http://download.java.net/maven/2/org/codehaus/mojo/maven-metadata.xml

397/397 B   

Downloaded: http://download.java.net/maven/2/org/codehaus/mojo/maven-metadata.xml (397 B at 0.0 KB/sec)
[WARNING] Failure to transfer org.apache.maven.plugins:maven-war-plugin/maven-metadata.xml from http://download.java.net/maven/2 was cached in the local repository, resolution will not be reattempted until the update interval of maven2-repository.dev.java.net has elapsed or updates are forced. Original error: Could not transfer metadata org.apache.maven.plugins:maven-war-plugin/maven-metadata.xml from/to maven2-repository.dev.java.net (http://download.java.net/maven/2): download.java.net
[INFO] 
[INFO] --- maven-war-plugin:2.3:war (default-cli) @ mywebapp-build ---
[INFO] Packaging webapp
[INFO] Assembling webapp [mywebapp-build] in [D:\workspace\target\mywebapp-build-0.0.1-SNAPSHOT]
[INFO] Processing war project
[INFO] Webapp assembled in [15 msecs]
[INFO] Building war: D:\workspace\target\mywebapp-build-0.0.1-SNAPSHOT.war
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Summary:
[INFO] 
[INFO] mywebapp ..................................... SUCCESS [27.999s]
[INFO] com.mywebapp [com.mywebapp] ..................... FAILURE [1:00.406s]
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 1:41.409s
[INFO] Finished at: Tue May 07 22:13:38 SGT 2013
[INFO] Final Memory: 11M/28M
[INFO] ------------------------------------------------------------------------
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-war-plugin:2.3:war 
(default-cli) on project mywebapp-build: Error assembling WAR: webxml attribute is required (or pre-existing WEB-INF/web.xml if executing in update mode)

6 个答案:

答案 0 :(得分:105)

查看settings.xml(或者可能是您项目的父级或公司父级POM)中的<repositories>元素。它看起来像下面的内容。

<repositories>
    <repository>
        <id>central</id>
        <url>http://gotoNexus</url>
        <snapshots>
            <enabled>true</enabled>
            <updatePolicy>always</updatePolicy>
        </snapshots>
        <releases>
            <enabled>true</enabled>
            <updatePolicy>daily</updatePolicy>
        </releases>
    </repository>
</repositories>

请注意<updatePolicy>元素。该示例告诉Maven在构建期间需要检索快照工件时检查是否有更新的副本,以便联系远程仓库(在我的情况下为Nexus,如果您没有使用自己的远程仓库,则为Maven Central)。这需要元数据。如果有更新的副本,Maven会将其下载到您当地的仓库。

在示例中,对于版本,策略为daily,因此它将在您当天的第一次构建期间进行检查。 never也是一个有效选项,如Maven settings docs中所述。

插件将单独解决。您也可以为这些存储库配置存储库,如果需要,可以使用不同的更新策略。

<pluginRepositories>
    <pluginRepository>
        <id>central</id>
        <url>http://gotoNexus</url>
        <snapshots>
            <enabled>true</enabled>
            <updatePolicy>daily</updatePolicy>
        </snapshots>
        <releases>
            <enabled>true</enabled>
            <updatePolicy>never</updatePolicy>
        </releases>
    </pluginRepository>
</pluginRepositories>

其他人提到了-o选项。如果您使用它,Maven将以“离线”模式运行。它知道它只有一个本地仓库,无论你使用什么更新策略,它都不会联系远程仓库来刷新工件。

答案 1 :(得分:22)

可能会使用标记-o,--offline "Work offline"来阻止它。

像这样:

maven compile -o

答案 2 :(得分:12)

我想因为你没有指定插件版本所以它会触发相关元数据的下载以获得最后一个。

否则您是否尝试使用-o?

强制使用本地存储库

答案 3 :(得分:0)

我尚未研究过,当Maven进行查找时,为了获得稳定且可重现的构建,我强烈建议不要直接访问Maven Respositories,而是使用Nexus等Maven资源库管理器。

以下是如何设置设置文件的教程:

http://books.sonatype.com/nexus-book/reference/maven-sect-single-group.html

http://maven.apache.org/repository-management.html

答案 4 :(得分:0)

Maven这样做是因为您的依赖项位于SNAPSHOT版本中,而maven无法检测存储库中对该快照版本所做的任何更改。释放工件,然后将pom.xml中的版本更改为该版本,然后maven将不再获取元数据文件。

答案 5 :(得分:0)

就我而言,我使用私有存储库管理器。虽然不推荐使用其他一些 Maven 存储库管理器。看起来 gradle 从已弃用的存储库管理器中查找我的私人工件。更新或删除已弃用的存储库管理器为我解决了这个问题。

相关问题