【发布时间】:2017-03-17 03:17:42
【问题描述】:
我目前正在开发一个部署在 heroku 中的 Spring Boot 应用程序。该应用程序在同一个仓库(前端和后端)上有 2 个主要项目。我已经设法使用 node.js 运行前端,并且(技术上)还设法运行 spring boot 应用程序。
2017-03-16T08:17:14.834886+00:00 app[api.1]: 2017-03-16 08:17:14.834 INFO 4 --- [main] o.s.web.servlet.DispatcherServlet: FrameworkServlet 'dispatcherServlet': initialization completed in 35 ms
2017-03-16T08:17:14.906139+00:00 app[api.1]: 2017-03-16 08:17:14.905 INFO 4 --- [main] com.zilicio.editor.ServerApplication: Started ServerApplication in 14.331 seconds (JVM running for 16.638)
2017-03-16T08:17:14.881330+00:00 app[api.1]: 2017-03-16 08:17:14.881 INFO 4 --- [main] .s.b.c.e.j.JettyEmbeddedServletContainer: Jetty started on port(s) 11831 (http/1.1)
根据该日志,一切似乎都正常,但是当我访问应用程序时,它返回一个 HTTP 500,声称没有 Web 进程正在运行。
2017-03-16T08:17:29.435087+00:00 heroku[router]: at=error code=H14 desc="No web processes running" method=GET path="/api/projects" (...)
但是当我检查 heroku ps 时
api.1: up 2017/03/16 03:16:56 -0500 (~ 30m ago)
这是我的过程文件:
web: node Z-Editor/Frontend/server.js
api: java -Dserver.port=$PORT $JAVA_OPTS -jar Z-Editor/Server/target/*.jar
它声明了2个进程(一个用于前端,一个用于服务器)。有 2 个不同的 heroku 应用程序运行每个 dynos。 node.js dyno 工作正常,但 Spring boot 没有。
这是repo的文件夹结构:
+root
- procfile
+ frontend
- package.json
- ...
+ server
- src
- pom.xml
+ target
- server.jar
- ...
- package.json
希望有人可以帮助我。
PD:根文件夹中的 package.json 和 pom.xml 与 frontend 和 server 文件夹中的相同。
【问题讨论】:
标签: heroku spring-boot