Flask - Déploiement

Serveur visible de l'extérieur

Une application Flask sur le serveur de développement est accessible uniquement sur l'ordinateur sur lequel l'environnement de développement est configuré. Il s'agit d'un comportement par défaut, car en mode débogage, un utilisateur peut exécuter du code arbitraire sur l'ordinateur.

Si debug est désactivé, le serveur de développement sur l'ordinateur local peut être mis à la disposition des utilisateurs sur le réseau en définissant le nom d'hôte comme ‘0.0.0.0’.

app.run(host = ’0.0.0.0’)

Ainsi, votre système d'exploitation écoute toutes les adresses IP publiques.

Déploiement

Pour passer d'un environnement de développement à un environnement de production à part entière, une application doit être déployée sur un vrai serveur Web. En fonction de ce que vous avez, différentes options sont disponibles pour déployer une application Web Flask.

Pour les petites applications, vous pouvez envisager de les déployer sur l'une des plates-formes hébergées suivantes, qui offrent toutes un plan gratuit pour les petites applications.

  • Heroku
  • dotcloud
  • webfaction

L'application Flask peut être déployée sur ces plates-formes cloud. De plus, il est possible de déployer l'application Flask sur la plateforme cloud de Google. Le service Localtunnel vous permet de partager votre application sur localhost sans modifier les paramètres DNS et de pare-feu.

Si vous êtes enclin à utiliser un serveur Web dédié à la place des plates-formes partagées mentionnées ci-dessus, les options suivantes sont à explorer.

mod_wsgi

mod_wsgi est un module Apache qui fournit une interface compatible WSGI pour l'hébergement d'applications Web basées sur Python sur un serveur Apache.

Installation de mod_wsgi

Pour installer une version officielle directement depuis PyPi, vous pouvez exécuter -

pip install mod_wsgi

Pour vérifier que l'installation a réussi, exécutez le script mod_wsgi-express avec la commande start-server -

mod_wsgi-express start-server

Cela lancera Apache / mod_wsgi sur le port 8000. Vous pouvez ensuite vérifier que l'installation a fonctionné en pointant votre navigateur sur -

http://localhost:8000/

Création d'un fichier .wsgi

Il devrait y avoir un yourapplication.wsgifichier. Ce fichier contient le codemod_wsgi,qui s'exécute au démarrage pour obtenir l'objet d'application. Pour la plupart des applications, le fichier suivant devrait suffire -

from yourapplication import app as application

Sois sûr que yourapplication et toutes les bibliothèques en cours d'utilisation se trouvent sur le chemin de chargement python.

Configurer Apache

Vous devez dire mod_wsgi, l'emplacement de votre application.

<VirtualHost *>
   ServerName example.com
   WSGIScriptAlias / C:\yourdir\yourapp.wsgi

   <Directory C:\yourdir>
      Order deny,allow
      Allow from all
   </Directory>

</VirtualHost>

Conteneurs WSGI autonomes

Il existe de nombreux serveurs populaires écrits en Python qui contiennent des applications WSGI et servent HTTP.

  • Gunicorn
  • Tornado
  • Gevent
  • Web tordu