uWSGI não consegue encontrar “aplicativo” usando o Flask e o Virtualenv

6

Usando o uWSGI para servir um aplicativo wsgi simples, (um simples "Hello, World") minha configuração funciona, mas quando tento executar um aplicativo Flask, recebo isso nos logs de erro do 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 ***'

Note em particular esta parte do log:

não foi possível encontrar "aplicativo" que pode ser chamado no arquivo /var/www/coefficient/flask.py

não é possível carregar o aplicativo 0 (ponto de montagem = '') (erro que pode ser chamado ou não encontrado)

****** nenhum aplicativo carregado. indo em modo dinâmico completo ******

Este é o meu aplicativo Flask:

from flask import Flask

app = Flask(__name__)

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

Antes de adicionar o pythonpath do Virtualenv ao meu arquivo de configuração, eu estava recebendo um ImportError for Flask. Eu resolvi isso, acredito (não estou mais recebendo erros) e aqui está meu arquivo de configuração completo:

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

É assim que eu inicio o uWSGI, a partir de um script rc:

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

E se eu tentar visualizar o programa Flask em um navegador, recebo isso:

**uWSGI Error**

Python application not found

Qualquer ajuda é apreciada.

    
por skyler 31.07.2012 / 15:07

2 respostas

13

unable to find "application" callable in file /var/www/coefficient/flask.py

é a chave:)

Seu aplicativo está definindo uma chamada de 'aplicativo', portanto você precisa instruir o uWSGI a pesquisá-lo, em vez de 'aplicativo'.

Você pode usar a opção

callable: app

e funcionará (isso é explicado nos documentos oficiais do Flask)

    
por 01.08.2012 / 07:43
3

Como alternativa, você pode adicionar module = flaskapp:app ao seu ini.

Além disso, callable é abordado em uwsgi-docs com mais clareza:

Flask exports its WSGI function (the one we called “application” at the beginning of this quickstart) as “app”, so we need to instruct uWSGI to use it: uwsgi --wsgi-file myflaskapp.py --callable app

    
por 19.05.2017 / 18:20