Guide de démarrage rapide pour .NET dans l'environnement flexible App Engine

Dans ce guide de démarrage rapide, vous allez apprendre à créer une petite application App Engine affichant un court message.

Avant de commencer

Avant d'exécuter et de déployer ce démarrage rapide, installez le SDK Cloud, puis configurez un projet GCP pour App Engine :

  1. Téléchargez et installez le SDK Cloud :

    Télécharger le SDK

    Remarque : Si le SDK Cloud est déjà installé, mettez-le à jour en exécutant la commande suivante :

    gcloud components update
    
  2. Créez un projet :

    gcloud projects create [YOUR_PROJECT_ID] --set-as-default
    

    Vérifiez que le projet a été créé :

    gcloud projects describe [YOUR_PROJECT_ID]
    

    Vous voyez alors les informations relatives au projet qui peuvent se présenter sous la forme suivante :

    createTime: year-month-hour
    lifecycleState: ACTIVE
    name: project-name
    parent:
    id: '433637338589'
    type: organization
    projectId: project-name-id
    projectNumber: 499227785679
    
  3. Initialisez votre application App Engine avec votre projet, puis choisissez sa région :

    gcloud app create --project=[YOUR_PROJECT_ID]
    

    Lorsque vous y êtes invité, sélectionnez la région dans laquelle vous souhaitez déployer votre application App Engine.

  4. Assurez-vous que la facturation est activée pour votre projet. Un compte de facturation doit être associé à votre projet pour que l'application puisse être déployée dans App Engine.

    Activer la facturation

    Tant qu'il est actif, le déploiement de votre environnement flexible engendre des coûts. Nettoyez votre projet lorsque vous avez terminé pour éviter des coûts permanents.

  5. Installez les composants requis suivants :

    • Installez le SDK .NET Core, version LTS.

    • Si vous utilisez Visual Studio, vous devez utiliser la version 2015 ou ultérieure. Les images sont disponibles pour les applications ASP.NET Core écrites pour .NET Core 1.0, 1.1, 2.0 et 2.1.

    • Pour procéder au déploiement sur App Engine directement à partir de Visual Studio, installez Cloud Tools for Visual Studio.

Emplacements App Engine

App Engine est régional, ce qui signifie que l'infrastructure qui exécute vos applications est située dans une région spécifique et gérée par Google pour être disponible de manière redondante dans toutes les zones de cette région.

Lors de la sélection d'une région dans laquelle exécuter vos applications, vous devez tout d'abord considérer vos exigences en matière de latence, de disponibilité et de durabilité. En règle générale, vous pouvez sélectionner la région la plus proche des utilisateurs de votre application, mais vous devez également tenir compte de l'emplacement des autres produits et services GCP exploités par votre application. L'utilisation des services dans plusieurs emplacements peut affecter la latence et les tarifs de votre application.

App Engine est disponible dans les régions suivantes :

  • northamerica-northeast1 (Montréal)
  • us-central (Iowa)
  • us-west2 (Los Angeles)
  • us-east1 (Caroline du Sud)
  • us-east4 (Virginie du Nord)
  • southamerica-east1 (São Paulo)
  • europe-west (Belgique)
  • europe-west2 (Londres)
  • europe-west3 (Francfort)
  • europe-west6 (Zurich)
  • asia-northeast1 (Tokyo)
  • asia-northeast2 (Osaka)
  • asia-east2 (Hong Kong)
  • asia-south1 (Mumbai)
  • australia-southeast1 (Sydney)

Une fois définie, vous ne pouvez plus modifier la région d'une application.

Si vous avez déjà créé une application App Engine, vous pouvez afficher la région en exécutant la commande gcloud app describe ou en ouvrant le tableau de bord App Engine dans la console GCP. La région de votre application App Engine est indiquée sous http://[YOUR_PROJECT_ID].appspot.com.

Ce guide de démarrage rapide suppose que vous maîtrisez la création d'applications Web avec C#.

Télécharger l'application Hello World

Nous avons créé une application Hello World simple pour .NET, afin de vous aider à comprendre rapidement comment déployer une application sur Google Cloud Platform. L'application Hello World est semblable à l'application créée par Visual Studio lorsqu'une application ASP.NET core vide est créée. L'exemple d'application ajoute un fichier app.yaml. Le fichier app.yaml est un fichier de configuration App Engine qui spécifie votre environnement d'exécution et d'autres paramètres App Engine.

  1. Clonez le dépôt de l'exemple d'application Hello World sur votre ordinateur.

    git clone https://github.com/GoogleCloudPlatform/dotnet-docs-samples
    

    Vous pouvez également télécharger l'exemple en tant que fichier zip et l'extraire.

  2. Accédez au répertoire qui contient l'exemple de code.

    cd dotnet-docs-samples/appengine/flexible/HelloWorld
    

Exécuter Hello World sur votre ordinateur local

Visual Studio

Pour exécuter l'application Hello World sur votre ordinateur local :

  1. Ouvrez dotnet-docs-samples\appengine\flexible\HelloWorld\HelloWorld.sln avec Visual Studio.
  2. Appuyez sur F5.

    Vous pouvez voir le message "Hello World" de l'exemple d'application affiché dans la page.

Ligne de commande

Pour exécuter l'application Hello World sur votre ordinateur local :

  1. Exécutez les commandes suivantes à partir du répertoire dotnet-docs-samples\appengine\flexible\HelloWorld :
    dotnet restore
    dotnet run
  2. Dans votre navigateur Web, accédez à http://localhost:5000/

    Vous pouvez voir le message "Hello World" de l'exemple d'application affiché dans la page.

  3. Dans votre fenêtre de terminal, appuyez sur Ctrl+C pour quitter le serveur Web.

Déployer et exécuter Hello World sur App Engine

Visual Studio

Pour déployer et exécuter l'application Hello World :

  1. Ouvrez dotnet-docs-samples\appengine\flexible\HelloWorld\HelloWorld.sln avec Visual Studio.
  2. Dans Solution Explorer (Explorateur de solutions), cliquez avec le bouton droit sur HelloWorld, puis choisissez Publish to Google Cloud… (Publier dans Google Cloud…)
  3. Cliquez sur App Engine Flex.
  4. Cliquez sur Publier.
  5. Pour voir votre application déployée, allez à l'adresse suivante dans votre navigateur :

    https://YOUR_PROJECT_ID.appspot.com

Ligne de commande

  1. Exécutez les commandes suivantes à partir du répertoire dotnet-docs-samples\appengine\flexible\HelloWorld :

    dotnet restore
    dotnet publish -c Release
    gcloud app deploy .\bin\Release\netcoreapp2.1\publish\app.yaml
  2. Lancez votre navigateur, puis saisissez l'adresse http://YOUR_PROJECT_ID.appspot.com pour afficher l'application.

    gcloud app browse

Cette fois, la page qui affiche le message Hello World est diffusée par un serveur Web exécuté sur une instance App Engine.

Félicitations ! Vous avez déployé votre première application .NET dans un environnement flexible App Engine.

Consultez les sections suivantes pour en savoir plus sur le nettoyage et découvrir les prochaines étapes que vous pourriez effectuer.

Nettoyer

Afin d'éviter que des frais ne vous soient facturés, vous pouvez supprimer votre projet GCP. Cette démarche interrompra la facturation de toutes les ressources utilisées dans le projet.

  1. Dans la console GCP, accédez à la page Gérer les ressources.

    Accéder à la page Gérer les ressources

  2. Dans la liste des projets, sélectionnez le projet que vous souhaitez supprimer, puis cliquez sur Supprimer .
  3. Dans la boîte de dialogue, saisissez l'ID du projet, puis cliquez sur Arrêter pour supprimer le projet.

Étapes suivantes

En savoir plus sur Google Cloud Platform

Maintenant que vous savez comment développer et déployer des applications App Engine, vous pouvez explorer le reste de GCP. Le SDK Cloud est déjà installé et vous permet d'interagir avec des produits tels que Cloud SQL, Cloud Storage, Cloud Firestore, etc.

Pour apprendre pas à pas à créer une application qui utilise l'ensemble de la plate-forme et pas seulement App Engine, accédez à notre guide de démarrage rapide pour créer l'application Bookshelf.

En savoir plus sur l'environnement flexible App Engine

Voici quelques articles qui vous aideront à mieux connaître App Engine :

Examen du code Hello World

Hello World est l'application App Engine la plus simple qui soit : elle ne contient qu'un seul service, ne possède qu'une seule version, et tout le code se trouve dans le répertoire racine de l'application. Cette section décrit chacun des fichiers de l'application en détail.

Startup.cs

L'application Hello World est une application ASP.NET simple :

    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        // For more information on how to configure your application, visit https://go.microsoft.com/fwlink/?LinkID=398940
        public void ConfigureServices(IServiceCollection services)
        {
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IHostingEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            app.Run(async (context) =>
            {
                string greeting = Configuration["My:Greeting"];
                await context.Response.WriteAsync(greeting);
            });
        }
    }

app.yaml

Le fichier app.yaml décrit la configuration de déploiement d'une application :

runtime: aspnetcore
env: flex

# This sample incurs costs to run on the App Engine flexible environment.
# The settings below are to reduce costs during testing and are not appropriate
# for production use. For more information, see:
# https://cloud.google.com/appengine/docs/flexible/python/configuring-your-app-with-app-yaml
manual_scaling:
  instances: 1
resources:
  cpu: 1
  memory_gb: 0.5
  disk_size_gb: 10

env_variables:
  # The __ in My__Greeting will be translated to a : by ASP.NET.
  My__Greeting: Hello AppEngine!

Ici, le fichier app.yaml spécifie l'environnement d'exécution utilisé par l'application et définit env: flex, qui indique que l'application utilise l'environnement flexible.