Guía de inicio rápido para utilizar .NET en el entorno de App Engine Flexible

ID de región

REGION_ID es un código abreviado que Google asigna en función de la región que seleccionas cuando creas la app. El código no corresponde a un país ni a una provincia, aunque algunos ID de región puedan parecer similares a los códigos de país y provincia que se suelen usar. En el caso de las apps creadas después de febrero de 2020, REGION_ID.r se incluye en las URL de App Engine. En el caso de las apps existentes creadas antes de esta fecha, el ID de región es opcional en la URL.

Obtén más información acerca de los ID de región.

Esta guía de inicio rápido describe cómo crear una aplicación pequeña de App Engine que muestre un mensaje breve.

Antes de comenzar

  1. Accede a tu cuenta de Google Cloud. Si eres nuevo en Google Cloud, crea una cuenta para evaluar el rendimiento de nuestros productos en situaciones reales. Los clientes nuevos también obtienen $300 en créditos gratuitos para ejecutar, probar y, además, implementar cargas de trabajo.
  2. En la página del selector de proyectos de la consola de Google Cloud, selecciona o crea un proyecto de Google Cloud.

    Ir al selector de proyectos

  3. Comprueba que la facturación esté habilitada en tu proyecto.

    Descubre cómo puedes habilitar la facturación

  4. Habilita Cloud Build API.

    Habilita la API

  5. Instala Google Cloud CLI.
  6. Para inicializar la CLI de gcloud, ejecuta el siguiente comando:

    gcloud init
  7. En la página del selector de proyectos de la consola de Google Cloud, selecciona o crea un proyecto de Google Cloud.

    Ir al selector de proyectos

  8. Comprueba que la facturación esté habilitada en tu proyecto.

    Descubre cómo puedes habilitar la facturación

  9. Habilita Cloud Build API.

    Habilita la API

  10. Instala Google Cloud CLI.
  11. Para inicializar la CLI de gcloud, ejecuta el siguiente comando:

    gcloud init

Requisitos previos adicionales

  1. Inicializa tu app de App Engine con el proyecto y selecciona su región:

    gcloud app create --project=[YOUR_PROJECT_ID]
    

    Cuando se te solicite, selecciona la región en la que deseas ubicar tu aplicación de App Engine.

  2. Instala los siguientes requisitos:

    • Instala el SDK de .NET Core, versión LTS.

    • Si estás usando Visual Studio, debes usar la versión 2015 o una posterior. Hay imágenes disponibles que pueden usarse con apps de ASP.NET Core escritas para .NET Core 1.0, 1.1, 2.0 y 2.1.

    • A fin de realizar implementaciones en App Engine directamente desde Visual Studio, instala herramientas para Visual Studio.

Ubicaciones de App Engine

App Engine es regional, lo que significa que la infraestructura que ejecuta las apps se encuentra en una región específica, y Google la administra para que esté disponible de forma redundante en todas las zonas dentro de esa región.

El cumplimiento de tus requisitos de latencia, disponibilidad o durabilidad debe ser un factor principal para seleccionar la región en la que se ejecutan las apps. Por lo general, puedes seleccionar la región más cercana a la de los usuarios de la app, pero debes considerar las ubicaciones en las que App Engine está disponible y las ubicaciones de los otros productos y servicios de Google Cloud que usa la app. Usar servicios en varias ubicaciones puede afectar la latencia de la app y sus precios.

No puedes cambiar la región de una app una vez configurada.

Si ya creaste una aplicación de App Engine, puedes ver su región mediante una de las siguientes opciones:

En esta guía de inicio rápido, se supone que estás familiarizado con la compilación de apps web con C #.

Descarga la app de Hello World

Creamos una app de Hello World sencilla para .NET a fin de que puedas familiarizarte con rapidez con la implementación de una app en Google Cloud. La app de Hello World es similar a la app que genera Visual Studio cuando se crea una app de ASP.NET Core vacía. La app de muestra agrega un archivo app.yaml. El archivo app.yaml es un archivo de configuración de App Engine que especifica tu entorno de ejecución y otras opciones de configuración de App Engine.

  1. Clona el repositorio de la app Hello World de muestra al equipo local.

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

    De manera opcional, puedes descargar la muestra como un archivo ZIP y extraerla.

  2. Cambia al directorio que contiene el código de muestra.

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

Ejecuta Hello World en tu máquina local

Visual Studio

Para ejecutar la app de Hello World en tu computadora local, haz lo siguiente:

  1. Abre dotnet-docs-samples\appengine\flexible\HelloWorld\HelloWorld.sln con Visual Studio.
  2. Presiona F5.

    Puedes ver el mensaje de "Hello World" desde la página de la app de muestra.

Línea de comandos

Para ejecutar la app de Hello World en tu computadora local, haz lo siguiente:

  1. Ejecuta los siguientes comandos desde el directorio dotnet-docs-samples\appengine\flexible\HelloWorld:
    dotnet restore
    dotnet run
  2. En tu navegador web, ve a http://localhost:5000/

    Puedes ver el mensaje de "Hello World" desde la página de la app de muestra.

  3. En la ventana de la terminal, presiona Ctrl + C para salir del servidor web.

Cómo implementar y ejecutar la app de Hello World en App Engine

Visual Studio

Para implementar la app de Hello World, sigue estos pasos:

  1. Abre dotnet-docs-samples\appengine\flexible\HelloWorld\HelloWorld.sln con Visual Studio.
  2. En el Explorador de soluciones, haz clic con el botón derecho en Hello World y elige Publish to Google Cloud…
  3. Haz clic en App Engine Flex.
  4. Haz clic en Publicar.
  5. Para ver tu app implementada, ve a la próxima dirección en tu navegador:

    https://PROJECT_ID.REGION_ID.r.appspot.com

Línea de comandos

  1. Ejecuta los siguientes comandos desde el directorio dotnet-docs-samples\appengine\flexible\HelloWorld:

    dotnet restore
    dotnet publish -c Release
    gcloud app deploy .\bin\Release\netcoreapp2.1\publish\app.yaml
  2. Inicia tu navegador y visualiza la aplicación en https://PROJECT_ID.REGION_ID.r.appspot.com

    gcloud app browse

Esta vez, la página que muestra el mensaje Hello World se envía mediante un servidor web que se ejecuta en una instancia de App Engine.

¡Felicitaciones! Implementaste la primera app de .NET en el entorno flexible de App Engine.

Si encontraste algún error cuando implementaste la aplicación, consulta las sugerencias para solucionar problemas.

Consulta las secciones siguientes para obtener información sobre la limpieza y vínculos a los próximos pasos que podrías realizar.

Realiza una limpieza

A fin de evitar que se apliquen cargos, puedes borrar el proyecto de Cloud para detener la facturación de todos los recursos que se usan en ese proyecto.

  1. En la consola de Google Cloud, ve a la página Administrar recursos.

    Ir a Administrar recursos

  2. En la lista de proyectos, elige el proyecto que quieres borrar y haz clic en Borrar.
  3. En el diálogo, escribe el ID del proyecto y, luego, haz clic en Cerrar para borrar el proyecto.

Próximos pasos

Conoce toda la plataforma

Ahora que sabes cómo implementar y desarrollar apps en App Engine, puedes explorar el resto de Google Cloud. Ya instalaste Google Cloud CLI, que te brinda las herramientas para interactuar con productos como Cloud SQL, Cloud Storage, Firestore y muchos otros.

Si deseas ver una explicación guiada que te enseñe a crear una app que use toda la plataforma, no solo App Engine, revisa nuestra guía de inicio rápido sobre la creación de la app de Bookshelf.

Aprende sobre el entorno flexible de App Engine

Aquí hay algunos temas para ayudarte a continuar tu aprendizaje sobre App Engine.

Revisión del código de Hello World

Hello World es la aplicación de App Engine más simple que pueda existir, dado que solo contiene un servicio, una versión y todo el código se ubica dentro del directorio raíz de la app. Esta sección describe cada archivo de la app en detalle.

Startup.cs

La app de Hello World es una app de 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

El archivo app.yaml describe la configuración de implementación de una app:

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!

Aquí, app.yaml especifica el entorno de ejecución que usa la aplicación y configura env: flex para especificar que esta aplicación usa el entorno flexible.