L'environnement d'exécution Python est la pile logicielle chargée d'installer le code et les dépendances de votre application, puis d'exécuter cette application dans l'environnement flexible.
Versions Python
Python 3.12 utilise des buildpacks. Pour obtenir la liste complète des versions de Python compatibles, ainsi que la version d'Ubuntu correspondante, consultez la page Programmation de la compatibilité avec l'environnement d'exécution.
Pour utiliser une version compatible de Python, vous devez effectuer les opérations suivantes :
Incluez les paramètres
runtime_config
etoperating_system
dans votre fichierapp.yaml
pour spécifier un système d'exploitation.Installer
gcloud
CLI version 420.0.0 ou ultérieure. Vous pouvez mettre à jour les outils de la CLI en exécutant la commandegcloud components update
. Pour afficher la version installée, exécutez la commandegcloud version
.Facultatif : vous pouvez spécifier une version d'exécution en incluant le paramètre
runtime_version
dans votre fichierapp.yaml
. Par défaut, la dernière version de Python est utilisée si le paramètreruntime_version
n'est pas spécifié.
Exemples
Pour spécifier Python 3.12 sur Ubuntu 22 :
runtime: python env: flex entrypoint: gunicorn -b :$PORT main:app runtime_config: operating_system: "ubuntu22" runtime_version: "3.12"
Pour spécifier la dernière version compatible de Python sur Ubuntu 22, procédez comme suit :
runtime: python env: flex entrypoint: gunicorn -b :$PORT main:app runtime_config: operating_system: "ubuntu22"
Pour en savoir plus, consultez la page de référence app.yaml
.
Versions précédentes de l'environnement d'exécution
Pour les versions 3.7 et antérieures de Python, vous spécifiez une version à l'aide des paramètres runtime_config
et python_version
dans le fichier app.yaml
de votre application.
Exemple
runtime: python
env: flex
entrypoint: gunicorn -b :$PORT main:app
runtime_config:
python_version: 3.7
Pour les versions d'exécution 3.7 et antérieures de Python, l'interpréteur par défaut est Python 2.7.12 si runtime_config
ou python_version
sont omis. Par exemple, vous pouvez utiliser l'environnement d'exécution par défaut en spécifiant runtime: python
dans votre fichier app.yaml
:
runtime: python
env: flex
Pour en savoir plus, consultez la page de référence app.yaml
.
Les interpréteurs déployés pour chaque paramètre de version sont présentés dans le tableau suivant :
Paramètre python_version |
Interpréteur déployé | ID d'exécution | Exemple app.yaml |
---|---|---|---|
2 (par défaut) |
2.7.12 | python2 |
runtime_config: python_version: 2 |
3.4 |
3.4.8 | python34 |
runtime_config: python_version: 3.4 |
3.5 |
3.5.9 | python35 |
runtime_config: python_version: 3.5 |
3 ou 3.6 |
3.6.10 | python36 |
runtime_config: python_version: 3 |
3.7 |
3.7.9 | python37 |
runtime_config: python_version: 3.7 |
Compatibilité avec d'autres environnements d'exécution Python
Si vous devez utiliser une version de Python non compatible, vous pouvez créer un environnement d'exécution personnalisé et sélectionner une image de base valide avec la version de Python dont vous avez besoin.
Pour les images de base fournies par Google ou les images de base Python Docker, consultez la section Créer des environnements d'exécution personnalisés.
Pour examiner plus en détail la conteneurisation d'applications App Engine pour Cloud Run, consultez le guide de migration.
Dépendances
L'environnement d'exécution recherche un fichier requirements.txt
dans le répertoire source de votre application et, avant de démarrer cette dernière, utilise pip
pour installer les dépendances. Pour plus d'informations sur la déclaration et la gestion des packages, consultez Utiliser les bibliothèques Python.
Si votre application nécessite des dépendances privées, vous devez utiliser un environnement d'exécution personnalisé basé sur l'environnement d'exécution Python pour installer les packages appropriés.
Démarrage de l'application
L'environnement d'exécution démarre l'application à l'aide de l'élément entrypoint
défini dans le fichier app.yaml
. Le point d'entrée doit démarrer un processus qui répond aux requêtes HTTP sur le port défini par la variable d'environnement PORT
.
La plupart des applications Web utilisent un serveur WSGI, tel que Gunicorn, uWSGI ou Waitress.
Avant de pouvoir utiliser l'un de ces serveurs, vous devez l'ajouter en tant que dépendance dans le fichier requirements.txt
de votre application.
Si vous utilisez gunicorn
pour votre application Flask, assurez-vous que la version de Python de votre application est compatible avec gunicorn
.
L'environnement d'exécution s'assure que toutes les dépendances sont installées avant d'appeler votre point d'entrée.
Flask==2.0.2
gunicorn==20.1.0
Voici un exemple de point d'entrée utilisant Gunicorn pour une application Flask :
entrypoint: gunicorn -b :$PORT main:app
Voici un exemple de point d'entrée utilisant Gunicorn pour une application Django :
entrypoint: gunicorn -b :$PORT mydjangoapp:wsgi
Gunicorn est le serveur WSGI recommandé, mais il est tout à fait possible d'utiliser un autre serveur WSGI. Par exemple, voici un point d'entrée qui utilise uWSGI avec Flask :
entrypoint: uwsgi --http :$PORT --wsgi-file main.py --callable app
Pour les applications capables de gérer des requêtes sans serveur WSGI, vous pouvez simplement exécuter un script Python :
entrypoint: python main.py
Configuration recommandée pour Gunicorn
Les exemples élémentaires de points d'entrée présentés ci-dessus sont destinés à servir de points de départ et peuvent convenir à vos applications Web. Cependant, la plupart des applications nécessitent une configuration plus avancée du serveur WSGI. Au lieu de spécifier tous les paramètres du point d'entrée, créez un fichier gunicorn.conf.py
dans le répertoire racine de votre projet, dans lequel se trouve le fichier app.yaml
, et spécifiez-le dans votre point d'entrée :
entrypoint: gunicorn -c gunicorn.conf.py -b :$PORT main:app
La documentation Gunicorn vous renseignera davantage sur toutes les valeurs de configuration que vous pouvez définir.
Nœuds de calcul
Gunicorn utilise des travailleurs pour traiter les requêtes. Par défaut, Gunicorn utilise des travailleurs synchrones. Cette classe est compatible avec toutes les applications Web, mais chaque travailleur ne peut gérer qu'une requête à la fois. Par défaut, Gunicorn n'en utilise qu'un. Cette manière de procéder peut souvent entraîner une sous-utilisation des instances et une latence accrue lorsque les applications sont soumises à une charge élevée.
Nous vous recommandons de définir un nombre de travailleurs compris entre 2 et 4 fois le nombre de cœurs de processeur de l'instance, plus un. Vous pouvez le spécifier dans le fichier gunicorn.conf.py
comme suit :
import multiprocessing
workers = multiprocessing.cpu_count() * 2 + 1
De plus, avec certaines applications Web principalement liées aux E/S, vous pouvez constater une amélioration des performances en utilisant une classe de travailleur différente.
Si votre classe de nœud de calcul nécessite des dépendances supplémentaires, telles que gevent ou tornado, ces dépendances doivent être déclarées dans le fichier requirements.txt
de votre application.
HTTPS et proxy de transfert
App Engine met fin à la connexion HTTPS au niveau de l'équilibreur de charge et transfère la requête à l'application. La plupart des applications n'ont pas besoin de savoir si la requête a été envoyée via HTTPS ou non, mais celles qui ont besoin de ces informations doivent configurer Gunicorn pour approuver le proxy App Engine dans leur fichier gunicorn.conf.py
:
forwarded_allow_ips = '*'
secure_scheme_headers = {'X-FORWARDED-PROTO': 'https'}
Gunicorn va maintenant s'assurer que l'élément wsgi.url_scheme
est défini sur 'https'
, ce que la plupart des frameworks Web interpréteront comme indiquant que la requête est sécurisée. Si votre serveur ou framework WSGI ne le permet pas, vérifiez manuellement la valeur de l'en-tête X-Forwarded-Proto
.
Certaines applications doivent également vérifier l'adresse IP de l'utilisateur. Cette option est disponible dans l'en-tête X-Forwarded-For
.
Le paramètre secure_scheme_headers
dans le fichier gunicorn.conf.py
doit être en majuscules (par exemple, X-FORWARDED-PROTO
), mais les en-têtes que votre code peut lire contiendront à la fois des lettres majuscules et minuscules (par exemple, X-Forwarded-Proto
).
Étendre l'environnement d'exécution
L'environnement d'exécution flexible Python peut être utilisé pour créer un environnement d'exécution personnalisé. Pour en savoir plus, consultez la section Personnaliser l'environnement d'exécution Python.
Variables d'environnement
Les variables d'environnement suivantes sont définies par l'environnement d'exécution :
Variable d'environnement | Description |
---|---|
GAE_INSTANCE |
Le nom de l'instance actuelle. |
GAE_MEMORY_MB |
La quantité de mémoire disponible pour le processus d'application. |
GAE_SERVICE |
Nom du service spécifié dans le fichier app.yaml de votre application. Si aucun nom de service n'est spécifié, il est défini sur default . |
GAE_VERSION |
Libellé de version de l'application en cours. |
GOOGLE_CLOUD_PROJECT |
ID du projet associé à votre application, visible dans la console Google Cloud. |
PORT |
Port qui reçoit les requêtes HTTP. |
Vous pouvez définir des variables d'environnement supplémentaires dans le fichier app.yaml
.
Serveur de métadonnées
Chaque instance de votre application peut utiliser le serveur de métadonnées Compute Engine pour rechercher des informations sur l'instance, y compris son nom d'hôte, son adresse IP externe, son ID d'instance, ses métadonnées personnalisées et ses informations de compte de service. App Engine ne vous permet pas de définir des métadonnées personnalisées pour chaque instance, mais vous pouvez définir des métadonnées personnalisées à l'échelle du projet et les lire à partir de vos instances App Engine et Compute Engine.
Cet exemple de fonction utilise le serveur de métadonnées pour obtenir l'adresse IP externe de l'instance :