uWSGI не может найти "приложение" с помощью Flask и Virtualenv

Используя uWSGI для обслуживания простого приложения wsgi (простое "Hello, World"), моя конфигурация работает, но когда я пытаюсь запустить приложение Flask, я получаю это в журналах ошибок uWSGI:

current working directory: /opt/python-env/coefficient/lib/python2.6/site-packages
writing pidfile to /var/run/uwsgi.pid
detected binary path: /opt/uwsgi/uwsgi
setuid() to 497
your memory page size is 4096 bytes
detected max file descriptor number: 1024
lock engine: pthread robust mutexes
uwsgi socket 0 bound to TCP address 127.0.0.1:3031 fd 3
Python version: 2.6.6 (r266:84292, Jun 18 2012, 14:18:47)  [GCC 4.4.6 20110731 (Red Hat 4.4.6-3)]
Set PythonHome to /opt/python-env/coefficient/
*** Python threads support is disabled. You can enable it with --enable-threads ***
Python main interpreter initialized at 0xbed3b0
your server socket listen backlog is limited to 100 connections
*** Operational MODE: single process ***
added /opt/python-env/coefficient/lib/python2.6/site-packages/ to pythonpath.
unable to find "application" callable in file /var/www/coefficient/flask.py
unable to load app 0 (mountpoint='') (callable not found or import error)
*** no app loaded. going in full dynamic mode ***
*** uWSGI is running in multiple interpreter mode ***`

Обратите особое внимание на эту часть журнала:

не удалось найти вызываемое приложение в файле /var/www/coefficient/flask.py

невозможно загрузить приложение 0 (точка монтирования ='') (вызываемое не найдено или ошибка импорта)

****** приложение не загружено. собирается в полном динамическом режиме ******

Это мое приложение Flask:

from flask import Flask

app = Flask(__name__)

@app.route("/")
def hello():
    return "Hello, World, from Flask!"

До того, как я добавил pythonpath Virtualenv в свой файл конфигурации, я получал ImportError для Flask. Я решил это, хотя, я полагаю (я больше не получаю ошибки об этом), и вот мой полный файл конфигурации:

uwsgi:
  #socket: /tmp/uwsgi.sock 
  socket: 127.0.0.1:3031
  daemonize: /var/log/uwsgi.log
  pidfile: /var/run/uwsgi.pid
  master: true
  vacuum: true
  #wsgi-file: /var/www/coefficient/coefficient.py
  wsgi-file: /var/www/coefficient/flask.py
  processes: 1
  virtualenv: /opt/python-env/coefficient/
  pythonpath: /opt/python-env/coefficient/lib/python2.6/site-packages

Вот как я запускаю uWSGI из rc-скрипта:

/opt/uwsgi/uwsgi --yaml /etc/uwsgi/conf.yaml --uid uwsgi

И если я пытаюсь просмотреть программу Flask в браузере, я получаю это:

**uWSGI Error**

Python application not found

Любая помощь приветствуется.

2 ответа

Решение

не удалось найти вызываемое приложение в файле /var/www/coefficient/flask.py

это ключ:)

Ваше приложение определяет вызываемое приложение, поэтому вы должны указать uWSGI выполнить его поиск вместо "приложения".

Вы можете использовать опцию

callable: app

и это будет работать (это объясняется в официальных документах Flask)

Кроме того, вы можете добавить module = flaskapp:app к твоему Ини.

Кроме того, действительно, callable более подробно рассматривается в uwsgi-docs:

Flask экспортирует свою функцию WSGI (ту, которую мы называли "application" в начале этого быстрого запуска) как "app", поэтому нам нужно указать uWSGI, чтобы она использовалась: uwsgi --wsgi-file myflaskapp.py --callable app

Другие вопросы по тегам