Ce tutoriel explique comment débuter avec Compute Engine. Suivez-le pour déployer une application Web Hello World en Node.js dans Compute Engine. Si vous avez besoin d'aide pour vous familiariser avec App Engine, consultez la page sur l'environnement standard App Engine.
Objectifs
- Télécharger et déployer un exemple d'application Hello World en utilisant Cloud Shell
- Déployer un exemple d'application Hello World sur une instance Compute Engine unique
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.
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 Compute Engine API.
-
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 Compute Engine API.
-
Dans la console Google Cloud, ouvrez l'application dans Cloud Shell.
Cloud Shell vous permet d'accéder en ligne de commande à vos ressources cloud, directement depuis votre navigateur.
-
Si vous acceptez de cloner le dépôt, cliquez sur Confirmer pour télécharger l'exemple de code et accéder au répertoire de l'application.
-
Dans Cloud Shell, configurez gcloud CLI pour utiliser votre nouveau projet Google Cloud:
# Configure gcloud for your project gcloud config set project YOUR_PROJECT_ID
Exécuter l'application dans Cloud Shell
Si vous avez cliqué sur Accéder à Cloud Shell dans la section précédente, Cloud Shell a cloné le dépôt nodejs-getting-started
sur votre instance. Une fois l'instance lancée, votre répertoire de travail est ~/cloudshell_open/nodejs-getting-started/gce
. Si vous ne vous trouvez pas dans ce répertoire, consultez les étapes de la section Avant de commencer.
Installez les dépendances :
npm install
Exécutez l'application :
npm start
Dans Cloud Shell, cliquez sur Aperçu sur le Web , puis sélectionnez Prévisualiser sur le port 8080. Une nouvelle fenêtre s'affiche avec votre application en cours d'exécution.
Pour arrêter le serveur Web local, appuyez sur les touches Ctrl+C.
Configurer Cloud Source Repositories
Activez l'API de Cloud Source Repositories.
Dans la console Google Cloud, accédez à Cloud Source Repositories.
Sélectionnez Add repository (Ajouter un dépôt).
Sélectionnez Créer un dépôt, puis cliquez sur Continuer.
Dans le champ Nom du dépôt, saisissez
new-repo
.Dans le champ Projet, saisissez l'ID du projet que vous avez créé ou sélectionné pour ce tutoriel, puis cliquez sur Continuer.
Sélectionnez Cloner votre dépôt vers un dépôt Git local.
Dans Cloud Shell, revenez à la racine et clonez le dépôt en suivant les instructions de l'onglet SDK Google Cloud, et gardez cet onglet ouvert.
Avant de terminer la dernière étape des instructions, copiez votre application dans votre nouveau dépôt au sein de Cloud Shell :
cd new-repo cp ../cloudshell_open/nodejs-getting-started/gce/app.js app.js cp ../cloudshell_open/nodejs-getting-started/gce/package.json package.json
Suivez les instructions restantes dans l'onglet SDK Google Cloud pour valider vos modifications dans le dépôt. Confirmez que vous avez ajouté votre code au dépôt en actualisant le navigateur et en vérifiant que votre code a été ajouté au dépôt
new-repo
.
Déployer sur une seule instance
Cette section décrit la procédure d'exécution d'une seule instance de votre application sur Compute Engine.
Depuis Cloud Shell, vous pouvez déployer une machine virtuelle (VM) d'instance unique Compute Engine, qui exécute votre application.
Utiliser un script de démarrage pour initialiser une instance
Vous avez besoin d'un outil qui indique à votre instance de télécharger et d'exécuter votre code. Une instance peut disposer d'un script de démarrage qui s'exécute à chaque démarrage ou redémarrage de l'instance.
Voici le script de démarrage inclus dans l'exemple d'application Hello World :
Le script de démarrage effectue les tâches suivantes :
Il installe l'agent Cloud Logging qui collecte automatiquement les journaux de syslog.
Il installe Supervisor pour exécuter l'application en tant que daemon.
Il clone le code source de l'application à partir de Cloud Source Repositories et installe des dépendances.
Il configure Supervisor pour exécuter l'application. Supervisor s'assure que l'application redémarre si elle se ferme de façon inattendue ou si elle est arrêtée par un administrateur ou un autre processus. Il envoie également les fichiers
stdout
etstderr
de l'application à syslog pour qu'ils soient collectés par l'agent Logging.
Créer et configurer une instance Compute Engine
Créez une instance Compute Engine :
Linux/macOS
gcloud compute instances create my-app-instance \ --image-family=debian-9 \ --image-project=debian-cloud \ --machine-type=g1-small \ --scopes userinfo-email,cloud-platform \ --metadata app-location=us-central1-f \ --metadata-from-file startup-script=gce/startup-script.sh \ --zone us-central1-f \ --tags http-server
Windows
gcloud compute instances create my-app-instance ^ --image-family=debian-9 ^ --image-project=debian-cloud ^ --machine-type=g1-small ^ --scopes userinfo-email,cloud-platform ^ --metadata-from-file startup-script=gce/startup-script.sh ^ --zone us-central1-f ^ --tags http-server
Remplacez la zone par une zone de développement. Exemple :
us-central1-a
. Pour en savoir plus sur les régions et les zones, consultez la page Zones géographiques et régions.Cette commande crée une instance, l'autorise à accéder aux services Google Cloud et exécute votre script de démarrage. Le nom de l'instance est
my-app-instance
.Vérifiez l'avancement de la création de l'instance :
gcloud compute instances get-serial-port-output my-app-instance --zone YOUR_ZONE
Remplacez
YOUR_ZONE
par la zone sur laquelle vous avez déployé votre instance.Une fois l'exécution du script de démarrage terminée, le message suivant s'affiche :
startup-script: INFO Finished running startup scripts.
Créez une règle de pare-feu pour autoriser le trafic vers votre instance :
gcloud compute firewall-rules create default-allow-http-8080 \ --allow tcp:8080 \ --source-ranges 0.0.0.0/0 \ --target-tags http-server \ --description "Allow port 8080 access to http-server"
Obtenez l'adresse IP externe de votre instance :
gcloud compute instances list
Pour voir votre application en cours d'exécution, saisissez cette URL dans votre navigateur :
http://YOUR_INSTANCE_IP:8080
Remplacez
YOUR_INSTANCE_IP
par l'adresse IP externe de votre instance.
Gérer et surveiller une instance
Vous pouvez surveiller et gérer votre instance à l'aide de la console GCP.
- In the Google Cloud console, go to the VM instances page.
- In the list of virtual machine instances, click SSH in the row of the instance that you want to connect to.
- Pour afficher tous les journaux générés par vos ressources Compute Engine, accédez à la page Explorateur de journaux.
Accéder à l'explorateur de journaux
Cloud Logging est automatiquement configuré de manière à collecter les journaux issus de divers services courants, comme
syslog
.
Effectuer un nettoyage
Pour éviter que les ressources utilisées lors de ce tutoriel soient facturées sur votre compte Google Cloud, supprimez le projet contenant les ressources, ou conservez le projet et supprimez les ressources individuelles.
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 les ressources individuelles
gcloud compute instances delete my-app-instance --zone=YOUR_ZONE --delete-disks=all gcloud compute firewall-rules delete default-allow-http-8080
Étapes suivantes
Découvrez des architectures de référence, des schémas et des bonnes pratiques concernant Google Cloud. Consultez notre Centre d'architecture cloud.
Pour obtenir d'autres ressources Node.js permettant de créer des applications, consultez les éléments suivants :
- Gérez et surveillez le déploiement de vos groupes d'instances depuis la page Compute Engine > Groupes d'instances.
- Gérez la configuration de votre équilibrage de charge, y compris les mappages d'URL et les services de backend, depuis la page Services réseau > Équilibrage de charge.
- Gérer les sessions à l'aide de Firestore
- Authentifiez les utilisateurs avec Identity-Aware Proxy.
- Déployer une application sur Google Kubernetes Engine
- Découvrez d'autres services Google Cloud.