在 heroku 上部署 Play2.1-RC1 会出现错误



当我将基于 Play2.1-RC1 的应用程序部署到 Heroku 时遇到此错误

[info] 'compiler-interface' not yet compiled for Scala 2.10.0-RC1. Compiling...
       sbt appears to be exiting abnormally.
         The log file for this session is at /tmp/sbt6398446576215517800.log
       java.lang.OutOfMemoryError: PermGen space
        at java.util.concurrent.FutureTask$Sync.innerGet(FutureTask.java:252)
        at java.util.concurrent.FutureTask.get(FutureTask.java:111)
        at sbt.ConcurrentRestrictions$$anon$4.take(ConcurrentRestrictions.scala:195)
        at sbt.Execute.next$1(Execute.scala:85)
        at sbt.Execute.processAll(Execute.scala:88)
        ...
            ...
     Error during sbt execution: java.lang.OutOfMemoryError: PermGen space  !  
     Failed to build app with sbt  !     
     Heroku push rejected, failed to compile Play 2.0 - scala app

构建属性

sbt.version=0.12.1

插件.sbt 文件

// Comment to get more information during initialization
logLevel := Level.Warn
// The Typesafe repository 
resolvers += "Typesafe repository" at "http://repo.typesafe.com/typesafe/releases/"

// Use the Play sbt plugin for Play projects
addSbtPlugin("play" % "sbt-plugin" % "2.1-RC1")

The Build.scala

导入sbt._导入PlayProject._

object ApplicationBuild extends Build {
  val appName = "myappname"
  val appVersion = "1.0-SNAPSHOT"
  val appDependencies = Seq(
    // Add your project dependencies here,
    jdbc,filters,
    "org.squeryl" % "squeryl_2.10.0-RC2" % "0.9.5-4",
    "postgresql" % "postgresql" % "9.1-901-1.jdbc4"
  )
  val main = play.Project(appName, appVersion, appDependencies).settings(
    // Add your own project settings here
  )
}

更新更改JAVA_OPTS和SBT_OPTS自 -Xmx384m -Xss512k -XX:+UseCompressedOops-Xmx1024m -Xss512k -XX:+UseCompressedOops

但又是同样的错误。

这是一个 PermGen 错误,请尝试添加:

-XX:PermSize=256m

这是一个已知问题,请查看 https://github.com/heroku/heroku-buildpack-scala/pull/26 和 https://github.com/heroku/heroku-buildpack-scala/tree/perm-gen

更新:

正如@ryanbrainard所指出的,perm-gen 问题已经在默认的 scala-buildpack 上得到解决,因此无需使用上面提到的特定构建包。

最新更新