Heroku上的Java Web App崩溃

时间:2015-07-11 21:55:24

标签: java maven heroku

我有一个现有的Java Web应用程序项目。我将它转换为maven项目并将其部署在Heroku上。应用程序已成功部署但未运行;它崩溃了。我无法从日志中弄清楚原因是什么。我的Procfile看起来像这样: web:java $ JAVA_OPTS -cp target / classes:target / m2e-wtp / * .jar

我在日志中看到的是应用程序崩溃,错误代码= H10,状态为503.我真的很感谢这方面的帮助。以下是日志:

app[web.1]: See http://www.oracle.com/technetwork/java/javase/documentation/index.html for more details.
heroku[web.1]: State changed from starting to crashed
heroku[web.1]: Process exited with status 1
heroku[api]: Scale to web=1 by charan7j86@gmail.com
heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/" host=fierce-woodland-8040.herokuapp.com request_id=9e462e2f-0e4f-4ef7-a503-e557fa46397a fwd="67.169.27.222" dyno= connect= service= status=503 bytes=
heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/favicon.ico" host=fierce-woodland-8040.herokuapp.com request_id=fcfb168d-3c62-4c0b-92ba-0a0418cdc703 fwd="67.169.27.222" dyno= connect= service= status=503 bytes=
heroku[web.1]: State changed from crashed to starting
heroku[web.1]: Starting process with command `java -XX:+UseCompressedOops -cp target/classes:target/m2e-wtp/*.jar`
app[web.1]: Usage: java [-options] class [args...]
app[web.1]:            (to execute a class)
app[web.1]:    or  java [-options] -jar jarfile [args...]
app[web.1]:            (to execute a jar file)
app[web.1]: where options include:
app[web.1]:     -d32      use a 32-bit data model if available
app[web.1]:     -d64      use a 64-bit data model if available
app[web.1]:                   The default VM is server,
app[web.1]:     -server      to select the "server" VM
app[web.1]:                   because you are running on a server-class machine.
app[web.1]: 
app[web.1]:     -cp <class search path of directories and zip/jar files>
app[web.1]: 
app[web.1]:     -classpath <class search path of directories and zip/jar files>
app[web.1]:                   A : separated list of directories, JAR archives,
app[web.1]:                   and ZIP archives to search for class files.
app[web.1]:     -D<name>=<value>
app[web.1]:                   set a system property
app[web.1]:     -verbose:[class|gc|jni]
app[web.1]:                   enable verbose output
app[web.1]:     -version      print product version and exit
app[web.1]:     -version:<value>
app[web.1]:                   require the specified version to run
app[web.1]:     -showversion  print product version and continue
app[web.1]:     -jre-restrict-search | -no-jre-restrict-search
app[web.1]:                   include/exclude user private JREs in the version search
app[web.1]:     -? -help      print this help message
app[web.1]:     -X            print help on non-standard options
app[web.1]:     -ea[:<packagename>...|:<classname>]
app[web.1]:     -enableassertions[:<packagename>...|:<classname>]
app[web.1]:                   enable assertions with specified granularity
app[web.1]:     -disableassertions[:<packagename>...|:<classname>]
app[web.1]:     -da[:<packagename>...|:<classname>]
app[web.1]:     -esa | -enablesystemassertions
app[web.1]:                   disable assertions with specified granularity
app[web.1]:                   enable system assertions
app[web.1]:     -dsa | -disablesystemassertions
app[web.1]:                   disable system assertions
app[web.1]:     -agentlib:<libname>[=<options>]
app[web.1]:                   load native agent library <libname>, e.g. -agentlib:hprof
app[web.1]:                   see also, -agentlib:jdwp=help and -agentlib:hprof=help
app[web.1]:     -agentpath:<pathname>[=<options>]
app[web.1]:                   load native agent library by full pathname
app[web.1]:     -javaagent:<jarpath>[=<options>]
app[web.1]:                   load Java programming language agent, see java.lang.instrument
app[web.1]:     -splash:<imagepath>
app[web.1]:                   show splash screen with specified image
app[web.1]: See http://www.oracle.com/technetwork/java/javase/documentation/index.html for more details.
heroku[web.1]: Process exited with status 1
heroku[web.1]: State changed from starting to crashed

1 个答案:

答案 0 :(得分:1)

Procfile中的命令未指定Main类。它应该看起来像:

 web: java $JAVA_OPTS -cp target/classes:target/m2e-wtp/*.jar com.foo.Main