29

我正在尝试将 Flask 应用程序部署到 Heroku 但是在推送代码时出现错误

2013-06-23T11:23:59.264600+00:00 heroku[web.1]: Error R10 (Boot timeout) -> Web process failed to bind to $PORT within 60 seconds of launch 

我不确定要尝试什么,我尝试将端口从 5000 更改为 33507,但无济于事。我的 Procfile 看起来像这样:

web: python main.py 

main.py是启动服务器的主要 Flask 文件。

谢谢。

4

4 回答 4

51

在 Heroku 上托管的 Flask 应用程序中,我使用以下代码启动服务器:

if __name__ == '__main__':
    # Bind to PORT if defined, otherwise default to 5000.
    port = int(os.environ.get('PORT', 5000))
    app.run(host='0.0.0.0', port=port)

在本地开发时,这将使用端口 5000,在生产中 Heroku 将设置PORT环境变量。

(旁注:默认情况下,Flask 只能从您自己的计算机访问,而不能从网络中的任何其他计算机访问(请参阅快速入门)。设置host='0.0.0.0'将使 Flask 从网络可用)

于 2013-06-24T13:08:59.973 回答
9

除了msiemens的回答

import os
from run import app as application
if __name__ == '__main__':
    port = int(os.environ.get('PORT', 5000))
    application.run(host='0.0.0.0', port=port)

您的 Procfile 应该指定在这种情况下存储在 heroku 环境变量 ${PORT} 中的端口地址

web: gunicorn --bind 0.0.0.0:${PORT} wsgi

于 2018-02-24T16:04:42.037 回答
4

您的main.py脚本无法绑定到特定端口,它需要绑定到$PORT环境变量中设置的端口号。Heroku 在调用您的应用程序之前在该变量中设置它想要的端口。

您收到的错误表明您正在绑定到一个不是 Heroku 期望的端口。

于 2013-06-23T17:24:24.443 回答
1

这也修复了H20: App boot timeout的问题。

我的 Procfile 看起来像这样:

web: gunicorn -t 150 -c gunicorn_config.py main:app --bind 0.0.0.0:${PORT}

和 main.py:

port = int(os.environ.get('PORT', 5000))
app.run(host='0.0.0.0', port=port)
于 2020-05-22T07:30:46.567 回答