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

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

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

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

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

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

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


当前回答

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

其他回答

您需要删除所有“_maven”。存储库中的文件。

您可以在本地存储库中删除相应的失败工件目录。你也可以在目标中使用-U。它会起作用的。这适用于maven 3。所以不需要降级到maven 2。

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

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

有些有关. .我正在

"[错误]未能在项目testproject上执行目标:无法解决项目myjarname:jar:1.0-0的依赖:在http://repo1.maven.org/maven2中无法找到myjarname-core:bundle:1.0-0在本地存储库中缓存,在中央更新间隔已经过或强制更新之前将不会重新尝试解决->[帮助1]"

此错误是由于意外地使用Maven 3而不是Maven 2引起的。只是觉得这可能会节省一些时间,因为我最初的谷歌搜索把我带到了这个页面。

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

[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