Recherche…


Wrapper d'application WSGI

De nombreuses applications Flask sont développées dans virtualenv pour conserver des dépendances pour chaque application, distinctes de l'installation Python à l'échelle du système. Assurez-vous que mod-wsgi est installé dans votre virtualenv :

pip install mod-wsgi

Créez ensuite un wrapper wsgi pour votre application Flask. Il est généralement conservé dans le répertoire racine de votre application.

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

Ce wrapper active l'environnement virtuel et tous ses modules et dépendances installés lorsqu'il est exécuté à partir d'Apache, et s'assure que le chemin de l'application est le premier dans les chemins de recherche. Par convention, les objets d'application WSGI sont appelés application .

Configuration des sites Apache pour WSGI

L'avantage d'utiliser Apache sur le serveur intégré Werkzeug est qu'Apache est multi-thread, ce qui signifie que plusieurs connexions à l'application peuvent être effectuées simultanément. Ceci est particulièrement utile dans les applications qui utilisent XmlHttpRequest (AJAX) sur le front-end.

/etc/apache2/sites-available/050-my-application.conf (ou configuration apache par défaut si elle n’est pas hébergée sur un serveur Web partagé)

<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>


Modified text is an extract of the original Stack Overflow Documentation
Sous licence CC BY-SA 3.0
Non affilié à Stack Overflow