使用maven,我偶尔会遇到来自第三方回购的工件,这些工件我还没有构建或包含在我的存储库中。

我将从maven客户端得到一个错误消息,说无法找到工件:

无法找到org.jfrog.maven.annomojo:maven-plugin-anno:jar:1.4.0 在http://myrepo:80/artifactory/repo中缓存在本地 存储库,解析将不会重新尝试,直到更新 MyRepo的时间间隔已过或更新被强制->[帮助1]

现在,我明白了这意味着什么,并且可以简单地用-U重新运行我的命令,从那时起,事情通常都能正常工作。

然而,我发现这个错误消息非常不直观,我试图让我的同事们不那么头疼。

我试图弄清楚是否有一些地方,我可以修改这个更新间隔设置。

此错误消息中提到的更新间隔是客户端设置还是服务器端设置? 如果是客户端,如何配置? 如果是服务器端,有人知道Nexus/Artifactory如何公开这些设置吗?


当前回答

对我来说,解决方案很愚蠢:我只是使用了不正确的依赖版本。

其他回答

在我的私有存储库上上传第三方库时,我也遇到了同样的问题。有时所描述的修复方法对我有效,但有时无效。

我认为问题的根本原因是工件缺少pom.xml文件。(第三方工件的pom.xml,而不是项目中的pom.xml)。我假设Maven期望每个工件都是pom.xml,因此它可以解析所有工件的依赖关系。有时没有pom.xml也能工作,但有时不能(我没有确定,什么时候不能)。

我使用Nexus3作为私有存储库。当您上传一个工件时,您可以选中一个选项来为工件生成一个pom.xml文件。

最后回答标题问题:它是(客户端设置)在(项目,配置文件或设置)

[plugin]?[r|R]epository/[releases|snapshots]/updatePolicy

... 标签。

(目前,maven: 3.6.0,但我认为“远远向后”兼容)可能的值是:

/** *从不更新本地缓存数据。 * / UPDATE_POLICY_NEVER = "never"; /** *总是更新本地缓存的数据。 * / public static final String UPDATE_POLICY_ALWAYS = "always"; /** *每天更新一次本地缓存数据。 * / UPDATE_POLICY_DAILY = "每日"; /** *更新本地缓存数据**每X分钟**由“interval:X”给出。 * / UPDATE_POLICY_INTERVAL = "interval";

当前(maven 3.6.0)对该标记的求值实现如下:

public boolean isUpdatedRequired( RepositorySystemSession session, long lastModified, String policy ) { boolean checkForUpdates; if ( policy == null ) { policy = ""; } if ( RepositoryPolicy.UPDATE_POLICY_ALWAYS.equals( policy ) ) { checkForUpdates = true; } else if ( RepositoryPolicy.UPDATE_POLICY_DAILY.equals( policy ) ) { Calendar cal = Calendar.getInstance(); cal.set( Calendar.HOUR_OF_DAY, 0 ); cal.set( Calendar.MINUTE, 0 ); cal.set( Calendar.SECOND, 0 ); cal.set( Calendar.MILLISECOND, 0 ); checkForUpdates = cal.getTimeInMillis() > lastModified; } else if ( policy.startsWith( RepositoryPolicy.UPDATE_POLICY_INTERVAL ) ) { int minutes = getMinutes( policy ); Calendar cal = Calendar.getInstance(); cal.add( Calendar.MINUTE, -minutes ); checkForUpdates = cal.getTimeInMillis() > lastModified; } else { // assume "never" checkForUpdates = false; if ( !RepositoryPolicy.UPDATE_POLICY_NEVER.equals( policy ) ) { LOGGER.warn( "Unknown repository update policy '{}', assuming '{}'", policy, RepositoryPolicy.UPDATE_POLICY_NEVER ); } } return checkForUpdates; }

. .:

private int getMinutes(String策略) { int分钟; 试一试 { 字符串s = policy。substring(RepositoryPolicy.UPDATE_POLICY_INTERVAL.length() + 1); minutes =整数。valueOf(s); } catch (RuntimeException) { 分钟= 24 * 60; 记录器。警告("不可解析的存储库更新策略'{}',假设'{}:1440'", 政策,RepositoryPolicy。UPDATE_POLICY_INTERVAL); } 返回分钟; }

...其中lastModified是(本地文件)一个/每个底层工件的“修改时间戳”。


特别是对于interval:x设置:

冒号:并不是那么严格——任何“非空”字符都可以这样做(=,,…)。 x < 0的负值应该屈服于"never"。 我假设是“分钟”(0-59秒)。或以上…)区间。 数字格式异常导致24 * 60分钟(~“daily”)。

..参见:DefaultUpdatePolicyAnalyzer, DefaultMetadataResolver#resolveMetadata()和RepositoryPolicy

我是怎么得到这个问题的,

当我从Eclipse Juno更改到Luna,并从SVN repo签出我的maven项目时,我在构建应用程序时遇到了同样的问题。

我试过什么? 我尝试清理本地存储库,然后再次使用-U选项更新所有版本。但我的问题还在继续。

然后我去了窗口—>首选项—> Maven—>用户设置—>,点击本地存储库下的重新索引按钮,等待重新索引发生。

就这样,问题解决了。

基本上发生的情况是,根据maven的默认updatePolicy, maven将每天从repo中获取jar。因此,如果在第一次尝试期间,您的互联网不工作,那么它将不会尝试再次获取这个罐子,直到24小时过去。

解决方法:

要么使用

mvn -U clean install

(此处-U将强制更新repo)

或使用

<profiles>
    <profile>
      ...
      <repositories>
        <repository>
          <id>myRepo</id>
          <name>My Repository</name>
          <releases>
            <enabled>false</enabled>
            <updatePolicy>always</updatePolicy>
            <checksumPolicy>warn</checksumPolicy>
          </releases>
         </repository>
      </repositories>
      ...
    </profile>
  </profiles>

在你的settings.xml中

我遇到了这个问题,文中提出的全面描述帮助我解决了它。

第二个问题是我的问题。我使用了我刚刚添加的第三方存储库,它在我的项目中做pom文件的存储库部分。我在pluginrepository中添加了相同的存储库信息来解决这个问题。