Google Cloud Platform (2/3) - AppEngine pour vos projets

Google Cloud Platform (2/3) - AppEngine pour vos projets


Vous avez souvent été bloqué dans vos projets parce qu'il est difficile de mettre en production. En effet, il faut des serveurs, les installer, les configurer et installer votre projet. Comment rendre cela plus simple ?

Avant de commencer ce tutoriel, il faut suivre les 2 premières étapes du tutoriel Google Cloud Platform (1/3).

Dans le tutoriel d'aujourd'hui, nous allons utiliser la solution AppEngine, qui vous permet de déployer facilement et directement depuis votre ordinateur votre application dans le Cloud. Par défaut AppEngine permet d'installer du Java, du Php, du Go et du Python, mais il permet aussi d'installer du Node, c'est d'ailleurs sur cette technologie que nous allons partir.

Etape 1, installer le sdk Google Cloud Platform

Je vous invite à suivre les instructions disponibles ici. Une fois l'installation terminée vous devriez pouvoir lancer la commande suivante dans votre terminal :

gcloud -help

Si ce n'est pas le cas, vérifiez votre installation.

Etape 2, créer votre projet node.js

Pour continuer nous allons faire simple en mettant en place un petit "Hello Word", avec Express.js.

Créez un nouveau dossier, ajoutez le fichier package.json :

//package.json { "name": "hello-word", "version": "1.0.0", "main": "index.js", "scripts": { "start": "node index.js" }, "dependencies": { "express": "^4.14.0" } }

Puis ajoutez le fichier index.js :

var express = require('express'); var app = express(); app.get('/', function (req, res) { res.send('Hello World!'); }); app.listen(8080, function () { console.log('Example app listening on port 8080!'); });

Si vous lancez dans votre terminal :

npm install && npm start

Normalement si vous suivez le lien http://localhost:8080/ un joli "Hello World!" s'affiche.

Etape 3, mettons du Cloud

Nous allons ajouter le fichier app.yaml qui permet de configurer votre AppEngine. Vous trouverez la documentation complète ici. Dans le fichier, nous allons mettre en place la configuration de base pour un environnement node.

runtime: nodejs env: flex

Comme vous pouvez le comprendre facilement, la première ligne permet de définir la technologie utilisée, la seconde ligne permet de choisir un environnement dit 'flex', ce qui signifie qu'il "s'auto scale" selon le trafic.

Etape 4, on met en production

La mise en prod est maintenant super simple, il vous suffit de vous mettre dans le dossier d'application et de lancer la commande suivante :

gcloud app deploy --version version1

L'option --version vous permet de donner un nom à votre version et de pouvoir la distinguer dans l'interface.

Etape 5, allons dans l'interface

Allez dans la console Cloud dans l'onglet AppEngine. Puis dans "versions" vous devriez voir la version de votre projet apparaître.

AppEngine - Google Cloud Platform

Quand le déploiement sera terminé, vous pourrez accéder à votre site en cliquant sur le nom de la version. Vous pouvez suivre les logs de l'application en lançant la commande suivante dans votre terminal :

gcloud app logs read -s default

Etape 6, créons une nouvelle version

Dans index.js changeons le message du "Hello World!" avec par exemple :

var express = require('express'); var app = express(); app.get('/', function (req, res) { res.send('Hello World V2!'); }); app.listen(8080, function () { console.log('Example app listening on port 8080!'); });

Puis lancez la commande :

gcloud app deploy --version version2

Dans l'interface AppEngine, vous devez voir la nouvelle version se lancer :

AppEngine V2 - Google Cloud Platform

Google enverra 100% du trafic sur la nouvelle version dès que celle-ci sera lancée entièrement. Une fois le processus terminé vous pouvez choisir vous même comment répartir le trafic.

Etape 7, répartir le trafic

La répartition du trafic permet de gérer un changement de version progressif de votre application. Pour procéder à cette répartition rien de plus simple, sélectionnez les versions avec lesquelles vous voulez travailler et cliquez sur "Répartir le trafic".

Vous arrivez sur l'interface suivante :

Répartir le traffic - Google Cloud Platform

Etape 8, Stopper les versions

Avant de partir, nous allons éteindre les versions, pour cela sélectionnez la version que vous souhaitez éteindre, puis cliquez sur "Arrêter".

Arreter - Google Cloud Platform

Je vous invite à jouer un peu avec AppEngine, il permet de très vite tester vos POC sur de vrais serveurs, et même de maintenir une charge importante pour vos projets.

Auteur(s)

Jonathan Jalouzot

Jonathan Jalouzot

Lead développeur au @lemondefr, mes technologies sont le symfony depuis 2009, le nodejs, l'angularjs, rabbitMq etc ... J'adore les médias et aimerai continuer dans ce secteur plein de surprise. Vous pouvez me retrouver sur les réseaux sociaux: Twitter: @captainjojo42 Instagram: @captainjojo42 Linkedin: https://fr.linkedin.com/in/jonathanjalouzot Github: https://github.com/captainjojo

Voir le profil

Vous souhaitez en savoir plus sur le sujet ?
Organisons un échange !

Notre équipe d'experts répond à toutes vos questions.

Nous contacter

Découvrez nos autres contenus dans le même thème

À la découverte de l'Anchor positioning API

La nouvelle Anchor positioning API en CSS

L'Anchor positioning API est arrivée en CSS depuis quelques mois. Expérimentale et uniquement disponible à ce jour pour les navigateurs basés sur Chromium, elle est tout de même très intéressante pour lier des éléments entre eux et répondre en CSS à des problématiques qui ne pouvaient se résoudre qu'en JavaScript.