Запуск API-интерфейсов Flask Restplus через Gunicorn

#python #flask #gunicorn #flask-restplus

#python #flask #gunicorn #flask-restplus

Вопрос:

У меня есть образец приложения Flask-RestPlus в виде myapp.py:

 from flask import Flask
from flask_restplus import Resource, API

API = Api(version='1.0', title='my_routes')
MY_NAMESPACE = API.namespace('v1.0/routes', description='v1.0 routes')


def initialize():
    app = Flask(__name__)
    API.init_app(app)
    API.add_namespace(MY_NAMESPACE)
    return app

@MY_NAMESPACE.route('/hello')
class HelloWorld(Resource):
    def get(self):
        return {'hello': 'world'}

if __name__ == '__main__':
    MY_ROUTE = initialize()
    MY_ROUTE.run(host='0.0.0.0', port=8080)
  

Это отлично работает, если я использую python myapp.py . Поскольку я хочу запустить этот код для запуска в производство, я хочу использовать Gunicorn. На моем компьютере с UNIX установлен gunicorn. Пример кода из https://gunicorn.org / работает совершенно нормально. Как мне запустить код в моем случае? Я пытался:

 gunicorn -w 4 myapp:initialize
gunicorn -w 4 "myapp:initialize()"
gunicorn -w 4 myapp:main
  

Но ни один из них не работал. Должен ли я вносить некоторые изменения в код?

Ответ №1:

В вашем myapp.py , поверните свою часть:

 if __name__ == '__main__':
    MY_ROUTE = initialize()
    MY_ROUTE.run(host='0.0.0.0', port=8080)
  

в:

 app = initialize() # app has to be accessible outside if

if __name__ == '__main__':
    app.run(host='0.0.0.0', port=8080)
  

а затем запустите

 gunicorn --bind 0.0.0.0:8080 --workers 4 myapp:app --log-level debug 
  

если вы хотите работать в рабочем режиме, укажите --log-level info .