根据 SBT 的官网文档中 Proxy Repositories 部分的描述, 可以通过改变 repositories
的 url
列表来优化.
配置国内代理库
感谢 OSChina 提供了 Maven Center 的镜像, 配置添加它有助于提升下载速度.
[repositories]
local
oschina:http://maven.oschina.net/content/groups/public/
若你知道其他更快的镜像库, 同上配置.
一般互联网企业部署了供内部使用的镜像库(如 nexus ), 也可以配置于此.
兼容 Ivy
路径布局
大多数中心仓库(repository)是 Maven 的路径布局, 这就导致 SBT 的插件和部分 Ivy 依赖无法从其下载.
[repositories]
local
oschina:http://maven.oschina.net/content/groups/public/
oschina-ivy:http://maven.oschina.net/content/groups/public/, [organization]/[module]/(scala_[scalaVersion]/)(sbt_[sbtVersion]/)[revision]/[type]s/[artifact](-[classifier]).[ext]
精简 url
列表
远程仓库越多越全, 可以基本避免下载不到的问题. 但是, 也可能让下载的时间更长, 让你不愿在等待而放弃下载.
因为, 下载过程中 SBT 会串行的 "询问" 列表中所有的远程仓库, 无论是否找得到.
当依赖树越大, 整个下载的过程就更漫长. 若再遇到响应慢的仓库, 情况恶化的令人发指.
推荐列表策略是:
本地仓库
国内(或内网)镜像仓库
国外官方仓库, 通常
#
注释掉, 待上面不管用时, 去掉#
再做尝试
上面办法不管用
建议使用你熟悉的网络嗅探手段查清具体原因, 对症下药了.
一个可行的方案
下载 HTTP 代理工具 mitmproxy, 并运行它
启动 SBT时, 附加参数
-Dhttp.proxyHost=loalhost -Dhttp.proxyPort=8080
, 这会将 SBT 所有的 HTTP 请求经由 mitmproxy转发通过 mitmproxy 来分析 HTTP 请求失败的具体原因
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。