Используя 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 (mountpoint = '') (вызываемый объект не найден или ошибка импорта)
****** Приложение не загружено. идет в полном динамическом режиме ******
Это мое приложение Flask:
from flask import Flask
app = Flask(__name__)
@app.route("/")
def hello():
return "Hello, World, from Flask!"
Прежде чем я добавил путь к python для 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
Любая помощь приветствуется.
невозможно найти вызываемое "приложение" в файле /var/www/coefficient/flask.py
это ключ :)
Ваше приложение определяет вызываемое приложение, поэтому вы должны указать uWSGI его поиск, а не приложение.
Вы можете использовать опцию
callable: app
и он будет работать (это объясняется в официальных документах Flask)
В качестве альтернативы вы можете добавить module = flaskapp:app
в ваш ini.
Кроме того, действительно, callable
адресован в uwsgi-docs более четко:
Flask экспортирует свою функцию WSGI (которую мы назвали «приложением» в начале этого краткого руководства) как «приложение», поэтому нам нужно проинструктировать uWSGI использовать ее:
uwsgi --wsgi-file myflaskapp.py --callable app