基本grails 3.3.8应用取消了heroku的内存限制

时间:2018-11-05 03:18:00

标签: heroku grails grails-3.3.x

我正在尝试编写一个简单的grails 3.3.8应用程序,我想将其部署到heroku。

我从一个简单的grails应用开始:

$ grails create-app example

然后我添加了一个Procfile:

web: ./gradlew bootRun -Dgrails.server.port=$PORT

还有到build.gradle的阶段任务:

task stage(dependsOn: assemble)

我认为这个应用程序什么也不做,因此不应该对512M heroku dyno施加压力,

2018-11-05T02:43:28.390592+00:00 app[web.1]: Picked up JAVA_TOOL_OPTIONS: -Xmx300m -Xss512k -XX:CICompilerCount=2 -Dfile.encoding=UTF-8
2018-11-05T02:43:32.587318+00:00 heroku[web.1]: Process running mem=729M(142.5%)
2018-11-05T02:43:32.587564+00:00 heroku[web.1]: Error R14 (Memory quota exceeded)
2018-11-05T02:43:36.536505+00:00 app[web.1]: :buildProperties
2018-11-05T02:43:37.378484+00:00 app[web.1]: :processResources
2018-11-05T02:43:37.381277+00:00 app[web.1]: :classes
2018-11-05T02:43:37.403505+00:00 app[web.1]: :findMainClass
2018-11-05T02:43:37.519404+00:00 app[web.1]: :bootRunPicked up JAVA_TOOL_OPTIONS: -Xmx300m -Xss512k -XX:CICompilerCount=2 -Dfile.encoding=UTF-8
2018-11-05T02:43:54.618402+00:00 heroku[web.1]: Process running mem=1164M(227.5%)
2018-11-05T02:43:54.618533+00:00 heroku[web.1]: Error R15 (Memory quota vastly exceeded)
2018-11-05T02:43:54.618676+00:00 heroku[web.1]: Stopping process with SIGKILL
2018-11-05T02:43:54.788397+00:00 heroku[web.1]: Process exited with status 137
2018-11-05T02:43:54.804734+00:00 heroku[web.1]: State changed from starting to crashed

1 个答案:

答案 0 :(得分:0)

bootRun用于本地运行和开发。它经过优化,可快速开发,而不是在生产中运行。

要在生产环境中运行,通常会运行

./gradlew assemble
# Deploy build/libs/app.jar(or war) to your server
java -jar app.jar 

还有许多方法可以运行spring-boot / grails应用程序,例如,部署到tomcat或其他servlet容器。