我正在使用docker来持续集成Scala项目。在容器中,我正在构建项目并创建一个带有"sbt“的发行版。
这需要很长时间才能消除所有的依赖项,我想使用一个码头数据卷,如下所示:volumes/
但是,我不明白如何让SBT将jar文件放在卷中,或者SBT如何知道如何从该卷中读取它们。
发布于 2014-02-27 15:06:20
SBT使用常春藤解决项目依赖关系。常春藤缓存本地下载的工件,每次它被要求提取某个东西时,它首先进入那个缓存,如果没有从远程找到下载的话。默认情况下,缓存位于~/.ivy2
中,但它实际上是一个configurable属性。因此,只需挂载卷,指向它(或者以默认位置挂载它)并享受缓存。
发布于 2014-11-30 07:12:10
不确定这在集成服务器上是否有意义,但在本地主机上开发时,我正在将主机的.ivy2/
和.sbt/
目录映射到容器中的卷,如下所示:
docker run ... -v ~/.ivy2:/root/.ivy2 -v ~/.sbt:/root/.sbt ...
(显然,在容器中,.ivy2/
和.sbt/
放在/root/
中,因为我们是作为根用户登录到容器中的。)
https://stackoverflow.com/questions/22069726
复制相似问题