Gunicorn无法启动Flask应用程序,因为“应用程序对象必须是可调用的”

时间:2018-11-12 08:18:07

标签: python python-3.x flask gunicorn wsgi

这可能是一个Python新手问题,但是经过一整天的搜索,我找不到解决方案。

我创建了一个简单的Flask应用程序,以下是python_pgfutter_importer / app.py的摘录:

import os

from flask import Flask, Blueprint

from python_pgfutter_importer import settings
from python_pgfutter_importer.api.importer.business import import_csv
from python_pgfutter_importer.api.importer.endpoints.csv import ns as csv_importer_namespace
from python_pgfutter_importer.api.restplus import api

app = Flask(__name__)


def initialize_app(flask_app):
    blueprint = Blueprint('api', __name__, url_prefix='/api')
    api.init_app(blueprint)
    api.add_namespace(csv_importer_namespace)
    flask_app.register_blueprint(blueprint)


def main():
    initialize_app(app)
    app.run(debug=settings.FLASK_DEBUG, use_reloader=settings.FLASK_USE_RELOADER)


if __name__ == "__main__":
    main()

应用程序运行良好,我使用以下命令启动它:

python python_pgfutter_importer/app.py

现在,我必须将此应用程序托管在服务器上,因此必须使用WSGI。使用我能找到的所有教程,我编写了这个WSGI入口点(wsgi.py):

from python_pgfutter_importer import app as application

if __name__ == "__main__":
    application.main()

启动Gunicorn时,这是CLI输出:

$gunicorn -b 127.0.0.1:8000 wsgi:application               
[2018-11-12 09:15:48 +0100] [11782] [INFO] Starting gunicorn 19.9.0
[2018-11-12 09:15:48 +0100] [11782] [INFO] Listening at: http://127.0.0.1:8000 (11782)
[2018-11-12 09:15:48 +0100] [11782] [INFO] Using worker: sync
[2018-11-12 09:15:48 +0100] [11785] [INFO] Booting worker with pid: 11785
Application object must be callable.
[2018-11-12 09:15:48 +0100] [11782] [INFO] Shutting down: Master
[2018-11-12 09:15:48 +0100] [11782] [INFO] Reason: App failed to load.

似乎是问题所在:应用程序对象必须是可调用的。

这没有任何意义,因为该应用程序是Flask并且可以调用。

我可能缺少什么?

谢谢

1 个答案:

答案 0 :(得分:5)

鉴于您的路径为python_pgfutter_importer/app.py,看来您在wsgi.py中的导入已关闭:

from python_pgfutter_importer import app as application

这使application成为模块对象,您需要一个应用程序:

from python_pgfutter_importer.app import app as application

或者,如果您将Gunicorn命令行中的wsgi.py更改为wsgi:application,则可以取消python_pgfutter_importer.app:appDocs