我的.sbt / repositories文件如下所示:
[repositories] local my-ivy-proxy-releases: http://our-nexus/nexus/content/groups/sbt_ivy_group/,[organization]/[module]/(scala_[scalaVersion]/)(sbt_[sbtVersion]/)[revision]/[type]s/[artifact](-[classifier]).[ext] my-maven-proxy-releases: http://our-nexus/nexus/content/groups/public/
网址很好,我可以在浏览器中打开它们.
现在,当我从命令行或IntelliJ IDEA运行sbt时,它会尝试从repo.scala-sbt.org,repo.typesafe.com等下载,即使我不想要它.
如何强制SBT仅从存储库文件中的存储库下载?
编辑:它确实从我们公司的nexus下载,但只是在尝试“官方”版本后,导致“连接被拒绝”的负载,因为我们落后于HTTP代理,这减慢了依赖性,解决了很多问题.
编辑2:我试图将-Dsbt.override.build.repos = true添加到IDEA的SBT设置的VM参数中,但这似乎没有任何改变.
解决方法
覆盖默认解析程序
解析器配置其他内联用户解析器.默认情况下,sbt将这些解析器与默认存储库(Maven Central和本地Ivy存储库)组合在一起以形成externalResolvers.要更好地控制存储库,请直接设置externalResolvers.除了通常的默认值之外,要仅指定存储库,请配置解析器.
例如,除了默认存储库之外,还要使用Sonatype OSS Snapshots存储库,
resolvers += "Sonatype OSS Snapshots" at "https://oss.sonatype.org/content/repositories/snapshots"
要使用本地存储库,而不是Maven Central存储库:
externalResolvers := Resolver.withDefaultResolvers(resolvers.value,mavenCentral = false)
覆盖所有构建的所有解析器
用于检索sbt,Scala,插件和应用程序依赖项的存储库可以全局配置,并声明为覆盖在构建或插件定义中配置的解析程序.有两个部分:
Define the repositories used by the launcher. Specify that these repositories should override those in build deFinitions.
可以通过定义〜/ .sbt / repositories来覆盖启动程序使用的存储库,这些存储库必须包含与Launcher规范配置文件格式相同的[repositories]部分.例如:
[repositories] local my-maven-repo: http://example.org/repo my-ivy-repo: http://example.org/ivy-repo/,[organization]/[module]/[revision]/[type]s/[artifact](-[classifier]).[ext]
可以通过sbt启动脚本中的sbt.repository.config系统属性指定存储库文件的其他位置.最后一步是将sbt.override.build.repos设置为true以使用这些存储库进行依赖项解析和检索.