【问题标题】:Deploy Scala binaries without dependencies部署没有依赖关系的 Scala 二进制文件
【发布时间】:2012-01-24 03:24:07
【问题描述】:

有没有一种简单的方法可以将 Scala Jar (~1MB) 复制到服务器,然后让 SBT 提取它需要的依赖项 (~40MB) 并运行它?

我见过 sbt-onejar 和 sbt-assembly,但是它们将所有依赖项捆绑到一个 jar 中,在我的情况下变成了 ~45MB,上传到服务器需要很长时间。

目前我使用 Capistrano 从 GitHub 签出我的代码并进行编译。然后我使用 xsbt-start-script-plugin 运行它 - 类似于 Heroku 的管理方式。

问题是在服务器上编译需要很长时间(我使用的是 EC2)。具有约 600MB ram 的 EC2 Micro 需要非常长的时间,有时会随机终止该进程。我正在使用目前正在运行的 EC2 小型实例(1.7GB 内存),但随着代码库的增加和我添加更多服务器,它可能会出现问题。

理想的工作流程是在本地(或在 CI 服务器上)编译 Scala 源代码,复制到服务器,让 SBT 拉入自上次构建以来添加的其他依赖项(现有的将来自本地缓存的 ivy 存储库),然后提供给我使用简单的脚本在 Ubuntu 10.04 上使用 Upstart 运行服务。

我也想听听其他 Scala 用户如何部署他们的代码。


(来自“答案”的代码稍后由 OP 发布)

FWIW 这是我的构建文件。

build.sbt

import com.typesafe.startscript.StartScriptPlugin
name := "XXX"
version := "0.1.0"
scalaVersion := "2.9.1"
resolvers += "XXX" at "http://repo.XXX.XXX"
libraryDependencies += "XXXX" %% "backend" % "0.1.0"
seq(StartScriptPlugin.startScriptForJarSettings: _*)
mainClass in Compile := Some("XXX.app.Main")

项目/build.sbt

resolvers += Classpaths.typesafeResolver
addSbtPlugin("com.typesafe.startscript" % "xsbt-start-script-plugin" % "0.5.0")
addSbtPlugin("com.eed3si9n" % "sbt-dirty-money" % "0.0.1")

【问题讨论】:

    标签: scala deployment jar sbt


    【解决方案1】:

    将您的 .jar 部署到服务器可以访问的存储库(我使用 Artifactory,但我认为您可以通过 scp 发布到文件系统)。创建一个空的 sbt 项目,它对您的应用程序的 .jar 文件具有单一依赖项。您的服务器可以拉和sbt update 这个空项目以利用本地 Ivy 缓存的方式将 jar 下载到服务器,并且对带宽非常友好。然后,只需获得正确的类路径来启动您的应用程序。

    您必须注意的一件事是确保 sbt 会真正更新您的依赖项。 SBT's mailing list 上有 some conversation about this

    启动应用程序的选项(按聪明程度排序)是:

    • 运行sbt run
    • 使用sbt-onejarsbt-assembly 创建单个.jar 并运行java -jar 来运行它
    • 编写一些 sbt 脚本来构建类路径,并使用它直接从 Ivy 缓存中启动应用程序。 我似乎记得最近在 SO 上看到过执行此操作的脚本,但目前找不到。您可以找到执行此操作的脚本in this SO answer,或者(如下所示)使用xsbt-start-script-plugin

    【讨论】:

    • 戴夫——也许你的意思是this script
    • 谢谢戴夫!我将在最后一步使用 xsbt-start-script-plugin。有想过这种部署方式,但是感觉有点奇怪。
    • @KiptonBarros 是的!我的意思就是那个脚本。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-03-07
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-09-08
    • 2018-06-19
    相关资源
    最近更新 更多