我使用hapi
创建了一个REST api,一切都在本地工作正常。我尝试在heroku
部署它,应用程序每次都崩溃,当我检查控制台是否有错误时显示:
无法加载资源:服务器favicon.ico以a响应 状态503(服务不可用)
我检查了如何处理这个问题,我发现很少有帖子说我需要添加一个端点来为/favicon.ico
返回状态代码204。一世
为它创建了一条路线如下:
server.route({
method: 'GET',
path: '/favicon.ico',
handler: function (request, reply) {
return reply(require('fs').createReadStream('../../favicon.ico')).code(200).type('image/x-icon');;
}
})
再次它在本地工作正常,但在heroku我得到相同的503错误。 heroku日志读起来像这样:
2018-02-25T04:56:18.826225+00:00 app[web.1]: Server running at: http://localhost:16689
2018-02-25T04:57:16.324815+00:00 heroku[web.1]: Error R10 (Boot timeout) -> Web process failed to bind to $PORT within 60 seconds of launch
2018-02-25T04:57:16.324815+00:00 heroku[web.1]: Stopping process with SIGKILL
2018-02-25T04:57:16.406578+00:00 heroku[web.1]: Process exited with
status 137
2018-02-25T04:57:16.418790+00:00 heroku[web.1]: State changed from starting to crashed
2018-02-25T06:57:16.527520+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/" host=profileapi.herokuapp.com
request_id=16403e1b-9e90-42f0-94c9-801960806944 fwd="157.49.157.106" dyno= connect= service= status=503 bytes= protocol=https
2018-02-25T06:57:17.983629+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/favicon.ico" host=profileapi.herokuapp.com request_id=67f40452-1a05-440f-962a-a045563a73af fwd="157.49.157.106" dyno= connect= service= status=503 bytes= protocol=https
2018-02-25T06:57:27.478816+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/favicon.ico" host=profileapi.herokuapp.com request_id=df2d9323-aa9d-4cff-9ef8-3722efda8a2f fwd="157.49.157.106" dyno= connect= service= status=503 bytes= protocol=https
2018-02-25T06:57:28.922698+00:00 heroku[router]: at=error code=H10 desc="App crashed" method=GET path="/favicon.ico" host=profileapi.herokuapp.com request_id=cc5088e6-fb7b-4c7b-8bcb-c2db8556dd8e fwd="157.49.157.106" dyno= connect= service= status=503 bytes= protocol=https
我查了hapi-favicon,模块用户指南文档为空。我检查了它用于/favicon.ico
端点的方式,我跟着它仍然得到相同的错误。
任何人都可以有任何建议/方法来解决这个问题吗?
答案 0 :(得分:0)
问题在于创建服务器时提供的host
地址,我将HOST
和PORT
添加到服务器连接,如下所示:
server.connection({
host: (process.env.HOST || 'localhost'),
port: (process.env.PORT || 1643)
});
Heroku动态地将应用程序分配给端口和主机地址。我们必须使用(process.env.PORT || your_port)
。同样,它将动态分配主机地址。我从连接中删除了主机。解决问题的最终连接如下:
server.connection({
port: (process.env.PORT || 1643)
});
答案 1 :(得分:0)
当我设置“引擎”时:{ “ node”:“ 10.4.1”, “ npm”:“ 6.4.2” }