加速 SBT 下载依赖库的速度

转载 2015年11月19日 13:25:41

SBT翻墙手册:http://afoo.me/posts/2014-11-05-how-make-sbt-jump-over-GFW.html

根据 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 会串行的 "询问" 列表中所有的远程仓库, 无论是否找得到.

当依赖树越大, 整个下载的过程就更漫长. 若再遇到响应慢的仓库, 情况恶化的令人发指.

推荐列表策略是:

  • 本地仓库
  • 国内(或内网)镜像仓库
  • 国外官方仓库, 通常 # 注释掉, 待上面不管用时, 去掉 # 再做尝试

上面办法不管用

我建议使用你熟悉的网络嗅探手段查清具体原因, 对症下药了.

一个可行的方案

  1. 下载 HTTP 代理工具 mitmproxy , 并运行它
  2. 启动 SBT 时, 附加参数 -Dhttp.proxyHost=loalhost -Dhttp.proxyPort=8080 , 这会将 SBT 所有的 HTTP 请求经由 mitmproxy 转发
  3. 通过 mitmproxy 来分析 HTTP 请求失败的具体原因

相关文章推荐

sbt项目构建过慢解决办法

最近因为环境迁移的原因需要重新构建一下之前的scala项目,然而被sbt过慢折磨的要死,打了一个多小时游戏还是卡在同一个进度不动,特地研究了一下处理了一波。sbt构建过慢原因sbt是scala项目经常...

sbt 超级慢--解决

本文转自http://www.cnblogs.com/shortboy/p/6069517.html 今天开始看Scala,入坑从maven编译改为sbt,在网上百度了半天老是报错,sbt镜像服务器...
  • dwryuan
  • dwryuan
  • 2017年02月20日 16:19
  • 1550

SBT下载特别慢的问题解决

sbt运行时经常需要下载大量的jar包,默认连接到maven官网,速度通常比较慢。 在`~/.sbt/`下添加一个`repositories`文件,里面内容如下: 帮助 1 2 3...

sbt第一次运行下载jar包很慢解决办法

一、补充sbt配置文件,添加下载路径 文件结构如下:修改了sbtconfig.txt,repo.properties.   sbtconfig.txt配置内容为: ...

Scala sbt 添加国内镜像

sbt运行时经常需要下载大量的jar包,默认连接到maven官网,速度通常比较慢。 在`~/.sbt/`下添加一个`repositories`文件,里面内容如下: [repositories] loc...
  • mmical
  • mmical
  • 2014年12月14日 16:04
  • 17404

sbt初次使用配置

1. 前言 2016年12月16日 为了搭建Spark,需要使用sbt。sbt使用Ivy,所以先花了点时间去学Ant+Ivy。 2016年12月17日 意识Ant+Ivy与Spark配置不相关,所以直...

sbt更改默认ivy仓库位置

转自: http://www.ituring.com.cn/article/132055 文档上有写: http://www.scala-sbt.org/0.13/docs/Launcher-...

Sbt仓库设置

每次sbt update的时候,都很慢,上火。原因是国内访问国外仓库,不给力。 改下repo仓库的设置就好了: 找到.sbt文件夹,一般在Administrator下,然后在.sbt里新建一个repo...

Spark快速入门之SBT安装

安装sbt本文方法有些繁琐,可以查看github最新更新:用sbt编译spark源码linux版本:CentOS6.7 sbt: 0.13.9 Spark中没有自带sbt,需要手动安装sbt,我...

Linux安装sbt过程详解

1. 下载sbt安装包下载地址点这里。2. 解压文件tar zxvf sbt-0.13.9.tgz 3. 建立启动sbt的脚本文件在./sbt目录下面新建文件名为sbt的文本文件$ cd ./sbt ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:加速 SBT 下载依赖库的速度
举报原因:
原因补充:

(最多只允许输入30个字)