En este instructivo, se muestra cómo implementar un ejemplo simple del servicio gRPC con el proxy de servicio extensible V2 (ESPv2) en un grupo de instancias administrado
En este instructivo, se usa la versión de Python del bookstore-grpc
de muestra. Consulta la sección Próximos pasos para ver muestras de gRPC en otros lenguajes.
Si quieres obtener una descripción general de Cloud Endpoints, consulta Acerca de Endpoints y Arquitectura de Endpoints.
Objetivos
Usa la siguiente lista de tareas de alto nivel a medida que avanzas en el instructivo. Todas las tareas son necesarias para enviar solicitudes a la API con éxito.
- Configura un proyecto de Google Cloud y descarga el software necesario. Consulta Antes de comenzar.
- Copia y configura archivos de la muestra
bookstore-grpc
. Consulta Configurar Endpoints. - Implementa la configuración de Endpoints para crear un servicio de este sistema. Consulta Cómo configurar Endpoints.
- Implementa la API y el ESPv2 en el backend del grupo de instancias administrado. Consulta Cómo implementar el backend de la API.
- Envía una solicitud a la API. Consulta Cómo enviar una solicitud a la API.
- Evita que se generen cargos en tu cuenta de Google Cloud. Consulta Limpiar.
Costos
En este instructivo, se usan los siguientes componentes facturables de Google Cloud:
Para generar una estimación de costos en función del uso previsto, usa la calculadora de precios.
Cuando finalices este instructivo, podrás borrar los recursos creados para evitar que se te siga facturando. Para obtener más información, consulta Cómo realizar una limpieza.
Antes de comenzar
- 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.
-
En la página del selector de proyectos de Google Cloud Console, selecciona o crea un proyecto de Google Cloud.
-
Asegúrate de que la facturación esté habilitada para tu proyecto de Cloud. Obtén información sobre cómo verificar si la facturación está habilitada en un proyecto.
-
En la página del selector de proyectos de Google Cloud Console, selecciona o crea un proyecto de Google Cloud.
-
Asegúrate de que la facturación esté habilitada para tu proyecto de Cloud. Obtén información sobre cómo verificar si la facturación está habilitada en un proyecto.
- Toma nota del ID del proyecto, ya que será necesario más tarde.
- Instala y, luego, inicializa Google Cloud CLI.
- Actualiza la CLI de gcloud y, luego, instala los componentes de Endpoints con el comando siguiente:
gcloud components update
-
Asegúrate de que Google Cloud CLI (
gcloud
) esté autorizado para acceder a tus datos y servicios en Google Cloud:gcloud auth login
En la pestaña del navegador nueva que se abre, selecciona una cuenta. -
Configura el proyecto predeterminado con tu ID del proyecto.
gcloud config set project YOUR_PROJECT_ID
Reemplaza YOUR_PROJECT_ID con el ID del proyecto. Si tienes otros proyectos de Google Cloud y deseas usar
gcloud
para administrarlos, consulta Cómo administrar configuraciones de gcloud CLI. - Sigue los pasos en la Guía de inicio rápido de Python de gRPC para instalar gRPC y sus herramientas.
Cuando finalices este instructivo, podrás borrar los recursos creados para evitar que se te siga facturando. Para obtener más información, consulta Cómo realizar una limpieza.
Configura Endpoints
Clona el repositorio de muestra bookstore-grpc
de GitHub:
Para configurar Endpoints, haz lo siguiente:
- Create a self-contained protobuf descriptor file from your service
.proto
file:- Save a copy of
bookstore.proto
from the example repository. This file defines the Bookstore service's API. - Create the following directory:
mkdir generated_pb2
- Create the descriptor file,
api_descriptor.pb
, by using theprotoc
protocol buffers compiler. Run the following command in the directory where you savedbookstore.proto
:python -m grpc_tools.protoc \ --include_imports \ --include_source_info \ --proto_path=. \ --descriptor_set_out=api_descriptor.pb \ --python_out=generated_pb2 \ --grpc_python_out=generated_pb2 \ bookstore.proto
In the preceding command,
--proto_path
is set to the current working directory. In your gRPC build environment, if you use a different directory for.proto
input files, change--proto_path
so the compiler searches the directory where you savedbookstore.proto
.
- Save a copy of
- Create a gRPC API configuration YAML file:
- Save a copy of the
api_config.yaml
file. This file defines the gRPC API configuration for the Bookstore service. - Replace MY_PROJECT_ID in your
api_config.yaml
file with your Google Cloud project ID. For example:# # Name of the service configuration. # name: bookstore.endpoints.example-project-12345.cloud.goog
Note that the
apis.name
field value in this file exactly matches the fully-qualified API name from the.proto
file; otherwise deployment won't work. The Bookstore service is defined inbookstore.proto
inside packageendpoints.examples.bookstore
. Its fully-qualified API name isendpoints.examples.bookstore.Bookstore
, just as it appears in theapi_config.yaml
file.apis: - name: endpoints.examples.bookstore.Bookstore
- Save a copy of the
Consulta Configurar Endpoints para obtener más información.
Implemente la configuración de Endpoints
Para implementar la configuración de Endpoints, usa el comando gcloud endpoints services deploy
. Este comando usa Service Management a fin de crear un servicio administrado.
- Asegúrate de estar en el directorio en el que se encuentran los archivos
api_descriptor.pb
yapi_config.yaml
. - Confirma que el proyecto predeterminado que se usa actualmente en la herramienta de línea de comandos de
gcloud
sea el proyecto de Google Cloud en el que deseas implementar la configuración de Endpoints. Valida el ID del proyecto que se muestra en el comando siguiente para asegurarte de que el servicio no se cree en el proyecto equivocado.gcloud config list project
Si necesitas cambiar el proyecto predeterminado, ejecuta el siguiente comando:
gcloud config set project YOUR_PROJECT_ID
- Implementa el archivo
proto descriptor
y el archivo de configuración mediante la CLI de Google Cloud:gcloud endpoints services deploy api_descriptor.pb api_config.yaml
Mientras se crea y configura el servicio, Administración de servicios exporta la información a la terminal. Cuando se completa la implementación, aparece un mensaje similar al siguiente:
Service Configuration [CONFIG_ID] uploaded for service [bookstore.endpoints.example-project.cloud.goog]
CONFIG_ID es el ID de configuración único del servicio de Endpoints que creó la implementación. Por ejemplo:
Service Configuration [2017-02-13r0] uploaded for service [bookstore.endpoints.example-project.cloud.goog]
En el ejemplo anterior,
2017-02-13r0
es el ID de configuración del servicio ybookstore.endpoints.example-project.cloud.goog
es el nombre del servicio. El ID de configuración del servicio consiste en una marca de fecha seguida de un número de revisión. Si implementas la configuración de Endpoints otra vez el mismo día, el número de revisión aumenta en el ID de configuración del servicio.
Verifica los servicios requeridos
Como mínimo, Endpoints y el ESP requieren que se habiliten los siguientes servicios de Google:Nombre | Título |
---|---|
servicemanagement.googleapis.com |
API de Service Management |
servicecontrol.googleapis.com |
API de Service Control |
endpoints.googleapis.com |
Google Cloud Endpoints |
En la mayoría de los casos, el comando de gcloud endpoints services deploy
habilita estos servicios obligatorios. Sin embargo, el comando gcloud
se completa de manera correcta sin habilitar los servicios requeridos en las circunstancias siguientes:
Usaste una aplicación de terceros, como Terraform, y no incluiste estos servicios.
Si implementaste la configuración de Endpoints en un proyecto existente de Google Cloud en el que se inhabilitaron explícitamente estos servicios
Usa el siguiente comando para confirmar que los servicios requeridos están habilitados:
gcloud services list
Si no ves los servicios necesarios que se incluyeron en la lista, habilítalos:
gcloud services enable servicemanagement.googleapis.comgcloud services enable servicecontrol.googleapis.com
gcloud services enable endpoints.googleapis.com
También habilita el servicio de Endpoints:
gcloud services enable ENDPOINTS_SERVICE_NAME
Para determinar la variable ENDPOINTS_SERVICE_NAME, puedes hacer lo siguiente:
Después de implementar la configuración de Endpoints, ve a la página Endpoints en Cloud Console. La lista de posibles ENDPOINTS_SERVICE_NAME se muestra en la columna Nombre del servicio.
Para OpenAPI, el ENDPOINTS_SERVICE_NAME es lo que especificaste en el campo
host
de tu especificación de OpenAPI. Para gRPC, el ENDPOINTS_SERVICE_NAME es lo que especificaste en el camponame
de tu configuración de Endpoints de gRPC.
Para obtener más información sobre los comandos gcloud
, consulta servicios de gcloud
.
Si recibes un mensaje de error, consulta Solucionar problemas con la implementación de la configuración de Cloud Endpoints. Consulta Cómo implementar la configuración de Endpoints para obtener información adicional.
Implementar el backend de la API
Hasta ahora, implementaste la configuración de API en Service Management, pero aún no implementaste el código que entrega el backend de la API. En esta sección, aprenderás a configurar Docker en tu grupo de instancias administrado y a ejecutar el código del backend de la API y el ESPv2 en un contenedor de Docker.
Crea una plantilla de instancias
Crea una plantilla que usarás para crear un grupo de instancias de VM. Cada instancia que se crea a partir de la plantilla inicia un ESPv2 y un servidor de aplicaciones de backend.
En Google Cloud Console, ve a la página Plantillas de instancia.
Haga clic en Crear plantilla de instancias.
En Nombre, ingresa
load-balancing-espv2-template
.En Configuración de máquina, establece el Tipo de máquina en
e2-micro
.En Disco de arranque, configura la Imagen como
Container Optimized OS stable version
.En Firewall, selecciona Permitir tráfico HTTP.
Haz clic en Administración, seguridad, discos, redes, instancia única para ver la configuración avanzada.
Haz clic en la pestaña Administración. En Automatización, ingresa la siguiente secuencia de comandos de inicio. Recuerda actualizar ENDPOINTS_SERVICE_NAME.
sudo docker network create --driver bridge esp_net sudo docker run \ --detach \ --name=bookstore \ --net=esp_net \ gcr.io/endpointsv2/python-grpc-bookstore-server:1 sudo docker run \ --detach \ --name=esp \ --publish=80:9000 \ --net=esp_net \ gcr.io/endpoints-release/endpoints-runtime:2 \ --service=ENDPOINTS_SERVICE_NAME \ --rollout_strategy=managed \ --listener_port=9000 \ --healthz=/healthz \ --backend=grpc://bookstore:8000
La secuencia de comandos obtiene, instala y, luego, inicia el servidor de aplicaciones Echo y el servidor proxy ESPv2 cuando se inicia la instancia.
Haz clic en Crear.
Espera hasta que se haya creado la plantilla antes de continuar.
Crea un grupo de instancias administrado regional.
Para ejecutar la aplicación, usa la plantilla de instancias a fin de crear un grupo de instancias administrado regional:
En la consola de Google Cloud, ve a la página Grupos de instancias.
Haga clic en Crear grupo de instancias.
En Nombre, ingresa
load-balancing-espv2-group
.En Ubicación, selecciona Varias zonas.
En Región, selecciona us-central1.
Haz clic en el menú desplegable Configurar zonas para mostrar las Zonas. Selecciona las siguientes zonas:
- us-central1-b
- us-central1-c
- us-central1-f
En Plantilla de instancias, selecciona
load-balancing-espv2-template
.En Ajuste de escala automático, selecciona No ajustar la escala de forma automática.
En Número de instancias, ingresa
3
.En Redistribución de instancias, selecciona Activada.
En Reparación automática y Verificación de estado, selecciona Sin verificación de estado.
Haz clic en Crear. Esto te redirecciona a la página Grupos de instancias.
Crea un balanceador de cargas
En esta sección, se explican los pasos necesarios para crear un balanceador de cargas regional que dirija el tráfico de TCP a tu grupo de instancias.
En la consola de Google Cloud, ve a la página Crear un balanceador de cargas.
En Balanceo de cargas TCP, haga clic en Iniciar configuración.
En Orientado a Internet o solo interno, selecciona De Internet a mis VM.
En Varias regiones o una sola región, selecciona Solo en una región.
En Tipo de backend, selecciona Servicio de backend.
Haz clic en Continuar.
En Nombre, ingresa
espv2-load-balancer
.En Configuración de backend, selecciona la región us-central1.
Selecciona el grupo de instancias
load-balancing-espv2-group
.En Verificación de estado, crea una verificación de estado nueva.
- En Nombre, ingresa
espv2-load-balancer-check
. - Confirme que el Protocolo sea TCP, que el Puerto sea 80.
- En Nombre, ingresa
En Configuración de frontend, ingresa el número de puerto 80.
En Revisar y finalizar, verifica lo siguiente:
- El Grupo de instancias es
load-balancing-espv2-group
. - La región es
us-central1
. - El Protocolo es
TCP
. - El IP:Puerto es
EPHEMERAL:80
.
- El Grupo de instancias es
Después de crear el balanceador de cargas, busca la dirección IP de la página Balanceador de cargas.
Envía una solicitud a la API
Si envías la solicitud desde la misma instancia en la que se ejecutan los contenedores de Docker, puedes reemplazar SERVER_IP por localhost
. De lo contrario, reemplaza SERVER_IP por la IP externa de la instancia.
Para buscar la dirección IP externa, ejecuta el comando siguiente:
gcloud compute instances list
To send requests to the sample API, you can use a sample gRPC client written in Python.
Clone the git repo where the gRPC client code is hosted:
git clone https://github.com/GoogleCloudPlatform/python-docs-samples.git
Change your working directory:
cd python-docs-samples/endpoints/bookstore-grpc/
Install dependencies:
pip install virtualenv
virtualenv env
source env/bin/activate
python -m pip install -r requirements.txt
Send a request to the sample API:
python bookstore_client.py --host SERVER_IP --port 80
Look at the activity graphs for your API in the Endpoints > Services page.
Go to the Endpoints Services page
It may take a few moments for the request to be reflected in the graphs.
Look at the request logs for your API in the Logs Explorer page.
Si no obtienes una respuesta correcta, consulta Solucionar errores en las respuestas.
¡Acabas de implementar y probar una API en Endpoints!
Realiza una limpieza
Para evitar que se apliquen cargos a tu cuenta de Google Cloud por los recursos usados en este instructivo, borra el proyecto que contiene los recursos o conserva el proyecto y borra los recursos individuales.
Asegúrate de que la CLI de gcloud (
gcloud
) esté autorizada para acceder a tus datos y servicios en Google Cloud:gcloud auth login
Ingresa lo siguiente para mostrar los ID de tus proyectos de Google Cloud:
gcloud projects list
Con el ID del proyecto aplicable del paso anterior, establece el proyecto predeterminado de Cloud en el que se encuentra tu aplicación:
gcloud config set project [YOUR_PROJECT_ID]
Obtén el nombre de todos los servicios administrados en tu proyecto de Cloud:
gcloud endpoints services list
Borra el servicio de Administración de servicios. Reemplaza
SERVICE_NAME
por el nombre del servicio que deseas quitar.gcloud endpoints services delete SERVICE_NAME
La ejecución de
gcloud endpoints services delete
no borra de inmediato el servicio administrado. La Administración de servicios inhabilita el servicio administrado durante 30 días, lo que te da tiempo para restablecerlo si es necesario. Luego de 30 días, la Administración de servicios borra el servicio administrado de forma permanente.Ve a la página Balanceador de cargas.
Borrar el balanceador de cargas
espv2-load-balancer
con la verificación de estadoespv2-load-balancer-check
.Ir a la página Grupos de instancias.
Borra
load-balancing-espv2-group
Ve a la página Plantilla de instancias.
Borrar
load-balancing-espv2-template
.
¿Qué sigue?
- Obtén información sobre cómo configurar tu propia API de gRPC para Endpoints.
- Mira la muestra de Bookstore con más detalle en GitHub. El cliente y el servidor están disponibles en Python y Java.
- La muestra
getting-started-grpc
está disponible en GitHub en los lenguajes siguientes: