【发布时间】:2012-02-29 18:22:22
【问题描述】:
我使用 Jenkins 作为 CI 服务器,Apache Ivy 用于管理 Android 项目的依赖关系,Artifactory 是托管所有工件的存储库。
在ivysettings.xml中,配置如下:
<ibiblio name="test" m2compatible="true"
root="http://ip:8888/artifactory/libs-snapshot-local"
pattern="[organisation]/[module]/1.0/[artifact]-**1.0**-SNAPSHOT.[ext]">
</ibiblio>
在 Jenkins 中构建时,我遇到了一个错误:
BUILD FAILED
C:\.jenkins\workspace\test\build.xml:1381: impossible to publish artifacts for com.test#dummy;working@myserver: java.io.IOException: PUT operation to URL http://ip:8888/artifactory/libs-snapshot-local/com/test/dummy/1.0/project-1.0-SNAPSHOT.apk failed with status code 500: Failed to save resource 'libs-snapshot-local:com/test/dummy/1.0/project-1.0-SNAPSHOT.apk'.
at org.apache.ivy.util.url.AbstractURLHandler.validatePutStatusCode(AbstractURLHandler.java:82)
at org.apache.ivy.util.url.BasicURLHandler.upload(BasicURLHandler.java:225)
at org.apache.ivy.util.url.URLHandlerDispatcher.upload(URLHandlerDispatcher.java:82)
at org.apache.ivy.util.FileUtil.copy(FileUtil.java:148)
at org.apache.ivy.plugins.repository.url.URLRepository.put(URLRepository.java:84)
at org.apache.ivy.plugins.repository.AbstractRepository.put(AbstractRepository.java:130)
at org.apache.ivy.plugins.resolver.RepositoryResolver.put(RepositoryResolver.java:234)
at org.apache.ivy.plugins.resolver.RepositoryResolver.publish(RepositoryResolver.java:216)
at org.apache.ivy.plugins.resolver.ChainResolver.publish(ChainResolver.java:244)
at org.apache.ivy.core.publish.PublishEngine.publish(PublishEngine.java:281)
at org.apache.ivy.core.publish.PublishEngine.publish(PublishEngine.java:260)
at org.apache.ivy.core.publish.PublishEngine.publish(PublishEngine.java:172)
at org.apache.ivy.Ivy.publish(Ivy.java:600)
at org.apache.ivy.ant.IvyPublish.doExecute(IvyPublish.java:311)
at org.apache.ivy.ant.IvyTask.execute(IvyTask.java:277)
at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:291)
at sun.reflect.GeneratedMethodAccessor4.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
at org.apache.tools.ant.Task.perform(Task.java:348)
at org.apache.tools.ant.Target.execute(Target.java:390)
at org.apache.tools.ant.Target.performTasks(Target.java:411)
at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1399)
at org.apache.tools.ant.Project.executeTarget(Project.java:1368)
at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
at org.apache.tools.ant.Project.executeTargets(Project.java:1251)
at org.apache.tools.ant.Main.runBuild(Main.java:809)
at org.apache.tools.ant.Main.startAnt(Main.java:217)
at org.apache.tools.ant.launch.Launcher.run(Launcher.java:280)
at org.apache.tools.ant.launch.Launcher.main(Launcher.java:109)
Total time: 9 seconds
Finished: FAILURE
但是,当我将突出显示的“1.0”更改为“1”时,它已成功发布到 Artifactory。它看起来像点'。不允许。还是我做错了什么?
请指教。
【问题讨论】:
-
你能检查一下 Artifactory 的日志是否包含任何错误/异常并发布它们吗?
-
我注意到的另一件事是,您正在将工件部署到一个所谓的 m2 兼容存储库,但查看部署路径,它似乎不符合 Maven 2 标准的一些原因。
-
您好 noamt,您能否解释一下为什么它不符合 m2 标准? Artifactory 日志只包含一行 500 错误代码,并没有详细的错误代码。
-
一方面,Maven没有OMRC(org、module、revision、classifier)和artifact的概念,而是GAVC(groupId、artifactId、version和classifier)。请注意,Ivy 的模块和工件可能不同。一般的 Maven 模式看起来像“[groupId]/[artifactId]/[version]/[artifactId]-[version]-([classifier]).[ext]”。您的模式不符合,因为工件 ID 不是路径的一部分,并且路径和文件名中的版本不同。
-
500 响应非常严重,您没有看到更详细的错误,这很奇怪;如果您可以在 github 上发布一个可以始终如一地重现它的示例测试项目,这也可能会有所帮助。
标签: ant jenkins ivy artifactory