Sin*_*son 5 java maven sbt typesafe-activator
我有一个服务器,可以自动构建一个play framework 2.3.4项目,并且可以成功构建我的开发分支.但是,当我构建不同的分支,在同一台服务器上使用相同的脚本时,我会遇到一些奇怪的行为.
构建由于某种原因获取调用的依赖项[actual dependency]-parent,这在其他分支上不会发生,也不会在我的本地计算机上构建有问题的分支.
例如:
在我当地:
[info] Resolving org.elasticsearch#elasticsearch;1.4.0 ...
[info] Resolving org.apache.lucene#lucene-core;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-analyzers-common;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-queries;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-memory;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-highlighter;4.10.2 ...
...
Run Code Online (Sandbox Code Playgroud)
关于CI构建:
[info] Resolving org.elasticsearch#elasticsearch;1.4.0 ...
[info] Resolving org.sonatype.oss#oss-parent;7 ...
[info] Resolving org.apache.lucene#lucene-core;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-parent;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-solr-grandparent;4.10.2 ...
[info] Resolving org.apache#apache;13 ...
[info] Resolving org.apache.lucene#lucene-analyzers-common;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-parent;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-queries;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-parent;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-memory;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-parent;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-highlighter;4.10.2 ...
[info] Resolving org.apache.lucene#lucene-parent;4.10.2 ...
...
Run Code Online (Sandbox Code Playgroud)
依赖org.sonatype.oss#oss-parent;7是全新的,在工作构建中没有org.sonatype.oss依赖.
然后在无法启动虚假应用程序之后测试失败,我认为这是由于错误的依赖性.
有谁知道是什么原因引起的?
这是我的build.sbt中的解析器的样子:
resolvers := Seq(
"Sonatype repo" at "https://oss.sonatype.org/content/repositories/releases/",
"Sonatype snapshots" at "https://oss.sonatype.org/content/repositories/snapshots/",
"Maven central repo" at "https://oss.sonatype.org/content/repositories/central/",
"Maven central repo2" at "https://repo1.maven.org/maven2/",
"Typesafe Repository" at "https://repo.typesafe.com/typesafe/releases/",
Resolver.url("Objectify Play Repository", url("http://schaloner.github.io/releases/"))(Resolver.ivyStylePatterns),
Resolver.url("Objectify Play Snapshot Repository", url("http://schaloner.github.io/snapshots/"))(Resolver.ivyStylePatterns),
Resolver.url("Edulify Repository", url("http://edulify.github.io/modules/releases/"))(Resolver.ivyStylePatterns),
Resolver.file("Local Repository", file(sys.env.get("PLAY_HOME").map(_ + "/repository/local").getOrElse("")))(Resolver.ivyStylePatterns),
Resolver.mavenLocal
)
Run Code Online (Sandbox Code Playgroud)
今天上午,2015年2月6日,两个分支机构合并,因此没有差异.但是,一个分支仍然构建但另一个分支失败(在相同的弹性实例上).每个构建都有自己的激活器实例,不共享存储库文件夹,但两个存储库文件夹是相同的.
根本原因可能是 oss.sonatype.org 存储库不久前从 http 转移到了 https,因此 sbt 试图通过 https 获取该依赖项,获得 301 重定向并对其进行轰炸。我怀疑您在本地看不到此内容的原因是您有缓存版本,可能吗?
我认为以下两种方法之一将帮助您克服它:
如果您有权访问 CI 服务器的 Maven 存储库,请尝试从本地 Maven 存储库复制正确的依赖项(删除当前缓存版本(如果有)后)。它通常位于运行 CI 服务器或构建进程的用户的主目录中,位于 ~/.m2/repository/org/sonatype/oss/oss-parent/7
我建议删除整个目录(如果有)并从本地已知良好的副本复制整个目录。
如果这不起作用或不可能,您可以考虑添加 sonatype 存储库的正确 https URL,在 sbt 中它看起来像这样:
resolvers += "Sonatype OSS Snapshots" at "https://oss.sonatype.org/content/repositories/snapshots"
Run Code Online (Sandbox Code Playgroud)
在 Build.scala 的适当部分...但是您可能仍然需要删除任何损坏的缓存版本的目录(如果它存在并且在构建中持续存在)。
| 归档时间: |
|
| 查看次数: |
382 次 |
| 最近记录: |