Ce tutoriel explique comment gérer des sessions sur App Engine.
De nombreuses applications requièrent une fonctionnalité de gestion de session pour l'authentification et le stockage des préférences utilisateur.
Le package sessions
de Gorilla Web Toolkit intègre une mise en œuvre basée sur un système de fichiers pour exécuter cette fonction. Cette mise en œuvre n'est toutefois pas adaptée à une application pouvant être diffusée depuis plusieurs instances. En effet, la session enregistrée dans une instance peut différer des autres instances. Le package gorilla/sessions
intègre également une implémentation basée sur les cookies. Toutefois, cette mise en œuvre nécessite le chiffrement des cookies et le stockage de la session entière sur le client plutôt qu'un ID de session, qui peut être trop volumineux pour certaines applications.
Objectifs
- Écrire l'application
- Exécuter l'application en local
- Déployer l'application sur App Engine
Coûts
Dans ce document, vous utilisez les composants facturables suivants de Google Cloud :
Obtenez une estimation des coûts en fonction de votre utilisation prévue à l'aide du simulateur de coût.
Une fois que vous avez terminé les tâches décrites dans ce document, vous pouvez éviter de continuer à payer des frais en supprimant les ressources que vous avez créées. Pour en savoir plus, consultez la section Effectuer un nettoyage.
Avant de commencer
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Firestore API.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Firestore API.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
Mettez à jour les composants
gcloud
:gcloud components update
- Préparer votre environnement de développement
Mettre en place le projet
Dans votre fenêtre de terminal, clonez le dépôt de l'exemple d'application sur votre machine locale :
git clone https://github.com/GoogleCloudPlatform/golang-samples.git
Accédez au répertoire qui contient l'exemple de code :
cd golang-samples/getting-started/sessions
Comprendre l'application Web
L'application affiche des messages d'accueil dans différentes langues pour chaque utilisateur. Les utilisateurs connus reçoivent toujours les messages d'accueil dans la même langue.
Pour que l'application puisse stocker les préférences d'un utilisateur, vous devez mettre en œuvre une méthode permettant de stocker les informations sur l'utilisateur actuel dans une session. Dans cet exemple d'application, les données de session sont stockées à l'aide de Firestore.
Vous pouvez utiliser firestoregorilla
, un magasin de sessions compatible avec gorilla/sessions
.
L'application commence par importer des dépendances, puis définit un type
app
devant contenir un élémentsessions.Store
et un modèle HTML, et enfin définit la liste des messages d'accueil.Ensuite, l'application définit une fonction
main
, qui crée une instanceapp
, enregistre le gestionnaire d'index et démarre le serveur HTTP. La fonctionnewApp
crée l'instanceapp
en initialisant unsessions.Store
avec la fonctionfirestoregorilla.New
.Le gestionnaire d'index obtient la session de l'utilisateur ou en crée une si nécessaire. Les nouvelles sessions se voient attribuer une langue aléatoire et un nombre de vues égal à 0. Ensuite, le nombre de vues est incrémenté d'une unité, la session est enregistrée et le modèle HTML écrit la réponse.
Le schéma suivant décrit la façon dont Firestore gère les sessions pour l'application App Engine.
Supprimer des sessions
firestoregorilla
ne supprime pas les sessions anciennes ou expirées. Google Cloud Console vous permet de supprimer les données de session. Vous pouvez également mettre en œuvre une stratégie de suppression automatique. Si vous utilisez des solutions de stockage pour des sessions telles que Memcache ou Redis, les sessions expirées sont automatiquement supprimées.
Exécution locale
Dans votre fenêtre de terminal, créez le fichier binaire
sessions
:go build
Démarrez le serveur HTTP :
./sessions
Affichez l'application dans votre navigateur Web :
Cloud Shell
Dans la barre d'outils Cloud Shell, cliquez sur Aperçu sur le Web et sélectionnez Prévisualiser sur le port 8080.
Machine locale
Dans votre navigateur, accédez à
http://localhost:8080
L'un des cinq messages d'accueil suivants s'affiche : "Hello World", "Hallo Welt", "Hola mundo", "Salut le Monde" ou "Ciao Mondo". La langue change si vous ouvrez la page dans un autre navigateur ou en mode navigation privée. Vous pouvez consulter et modifier les données de session dans la console Google Cloud.
Dans votre fenêtre de terminal, appuyez sur
Control+C
pour arrêter le serveur HTTP.
Déployer et exécuter l'application sur App Engine
Vous pouvez utiliser l'environnement standard App Engine pour créer et déployer une application qui s'exécute de manière fiable, même lorsqu'elle est soumise à une charge importante et doit gérer de grandes quantités de données.
Dans ce tutoriel, le serveur est déployé dans l'environnement standard App Engine.
Le fichier app.yaml
contient la configuration d'environnement standard d'App Engine :
Déployez l'application sur App Engine :
gcloud app deploy
Dans votre navigateur Web, saisissez l'URL suivante :
https://PROJECT_ID.REGION_ID.r.appspot.com
Remplacez les éléments suivants :
PROJECT_ID
: ID de votre projet Google Cloud.REGION_ID
: code attribué par App Engine à votre application
Le message d'accueil est désormais diffusé par un serveur Web exécuté sur une instance App Engine.
Déboguer l'application
Si vous ne parvenez pas à vous connecter à votre application App Engine, vérifiez les éléments suivants :
- Vérifiez que les commandes de déploiement
gcloud
ont bien abouti et n'ont généré aucune erreur. Si des erreurs se sont produites (par exemple,message=Build failed
), corrigez-les, puis essayez de redéployer l'application App Engine. Dans Google Cloud Console, accédez à la page Explorateur de journaux.
Accéder à la page "Explorateur de journaux"
Dans la liste déroulante Ressources sélectionnées récemment, cliquez sur Application App Engine, puis sur Tous les ID de module. La liste des requêtes correspondant à votre accès à l'application s'affiche. Si cette liste n'apparaît pas, vérifiez que vous avez bien sélectionné Tous les ID de module dans la liste déroulante. Si des messages d'erreur s'affichent dans la console Google Cloud, vérifiez que le code de votre application correspond le code de la section sur l'écriture de l'application Web.
Assurez-vous que l'API Firestore est activée.
Effectuer un nettoyage
Supprimer le projet
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.
Supprimer l'instance App Engine
- In the Google Cloud console, go to the Versions page for App Engine.
- Select the checkbox for the non-default app version that you want to delete.
- Pour supprimer la version de l'application, cliquez sur Supprimer.
Étape suivante
- Découvrez les tutoriels Cloud Run Functions.
- Obtenez plus d'informations sur App Engine.
- Essayez Cloud Run, qui vous permet d'exécuter des conteneurs sans état dans un environnement entièrement géré ou dans votre propre cluster Google Kubernetes Engine.