Flask
Flask on Apache con mod_wsgi
Ricerca…
WSGI Application wrapper
Molte applicazioni Flask sono sviluppate in un virtualenv per mantenere le dipendenze per ogni applicazione separata dall'installazione Python a livello di sistema. Assicurati che mod-wsgi sia installato nel tuo virtualenv :
pip install mod-wsgi
Quindi crea un wrapper wsgi per l'applicazione Flask. Di solito è conservato nella directory principale dell'applicazione.
my-application.wsgi
activate_this = '/path/to/my-application/venv/bin/activate_this.py'
execfile(activate_this, dict(__file__=activate_this))
import sys
sys.path.insert(0, '/path/to/my-application')
from app import app as application
Questo wrapper attiva l'ambiente virtuale e tutti i suoi moduli e dipendenze installati quando viene eseguito da Apache e si assicura che il percorso dell'applicazione sia il primo nei percorsi di ricerca. Per convenzione, gli oggetti dell'applicazione WSGI sono chiamati application
.
Configurazione abilitata per i siti Apache per WSGI
Il vantaggio di utilizzare Apache sul server werkzeug incorporato è che Apache è multi-thread, il che significa che è possibile effettuare più connessioni simultaneamente all'applicazione. Ciò è particolarmente utile nelle applicazioni che utilizzano XmlHttpRequest (AJAX) sul front-end.
/etc/apache2/sites-available/050-my-application.conf (o configurazione di apache predefinita se non ospitata su un server web condiviso)
<VirtualHost *:80>
ServerName my-application.org
ServerAdmin [email protected]
# Must be set, but can be anything unless you want to serve static files
DocumentRoot /var/www/html
# Logs for your application will go to the directory as specified:
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
# WSGI applications run as a daemon process, and need a specified user, group
# and an allocated number of thread workers. This will determine the number
# of simultaneous connections available.
WSGIDaemonProcess my-application user=username group=username threads=12
# The WSGIScriptAlias should redirect / to your application wrapper:
WSGIScriptAlias / /path/to/my-application/my-application.wsgi
# and set up Directory access permissions for the application:
<Directory /path/to/my-application>
WSGIProcessGroup my-application
WSGIApplicationGroup %{GLOBAL}
AllowOverride none
Require all granted
</Directory>
</VirtualHost>