在 Heroku 上部署 Golang 应用程序:构建成功,但应用程序错误
在具有 Go 依赖支持的 Heroku 上部署 Golang 应用程序时,您尝试访问端点时可能会遇到“应用程序错误”。当 Web 服务器未正确绑定到 Heroku 上的相应端口时,就会出现此问题。
您的应用程序日志消息指示以下错误:
Error R10 (Boot timeout) -> Web process failed to bind to $PORT within 60 seconds of launch
原因:
该问题是由于尝试在硬编码端口 (9000) 上启动服务器而不是将其绑定到由Heroku 的 $PORT 环境变量。
解决方案:
要解决此问题,请使用 $PORT 环境变量在正确的端口上启动服务器。将现有代码替换为:
err := grace.Serve(":9000", context.ClearHandler(http.DefaultServeMux))
使用以下内容:
port := os.Getenv("PORT") if port == "" { port = "9000" // Default port if not specified } err := grace.Serve(":" + port, context.ClearHandler(http.DefaultServeMux))
此更改可确保服务器正确绑定到 Heroku 指定的端口,从而解决“应用程序错误”问题。
以上是为什么 Heroku 上的 Golang 应用程序在成功构建后显示'应用程序错误”?的详细内容。更多信息请关注PHP中文网其他相关文章!