1. Descripción general
Esta serie de codelabs (instructivos prácticos y de autoaprendizaje) tiene como objetivo ayudar a los desarrolladores a comprender las diferentes opciones que tienen cuando implementan sus aplicaciones. En este codelab, aprenderás a usar la API de Google Cloud Translation con Python y a ejecutarla de forma local o implementarla en una plataforma de procesamiento sin servidores de Cloud (App Engine, Cloud Functions o Cloud Run). La app de ejemplo que se encuentra en el repositorio de este instructivo se puede implementar de (al menos) ocho maneras diferentes con solo cambios menores de configuración:
- Servidor Flask local (Python 2)
- Servidor Flask local (Python 3)
- App Engine (Python 2)
- App Engine (Python 3)
- Cloud Functions (Python 3)
- Cloud Run (Python 2 a través de Docker)
- Cloud Run (Python 3 a través de Docker)
- Cloud Run (Python 3 a través de paquetes de compilación de Cloud)
Este codelab se enfoca en implementar esta app en las plataformas en negrita anteriores.
Obtendrás información para hacer las siguientes acciones
- Usar las APIs de Google Cloud, específicamente la API de Cloud Translation (avanzada/v3)
- Ejecuta una aplicación web básica de forma local o impleméntala en una plataforma de procesamiento sin servidores de Cloud.
Requisitos
- Un proyecto de Google Cloud con una cuenta de Facturación de Cloud activa
- Flask instalado para ejecutarse de forma local o una plataforma de procesamiento sin servidores de Cloud habilitada para implementaciones basadas en la nube
- Habilidades básicas de Python
- Conocimiento práctico de los comandos básicos del sistema operativo
Encuesta
¿Cómo usarás este instructivo?
¿Cómo calificarías tu experiencia en Python?
¿Cómo calificarías tu experiencia en el uso de los servicios de Google Cloud?
2. Configuración y requisitos
Configuración del entorno de autoaprendizaje
- Accede a Google Cloud Console y crea un proyecto nuevo o reutiliza uno existente. Si aún no tienes una cuenta de Gmail o de Google Workspace, debes crear una.
- El Nombre del proyecto es el nombre visible de los participantes de este proyecto. Es una string de caracteres que no se utiliza en las API de Google y se puede actualizar en cualquier momento.
- El ID del proyecto debe ser único en todos los proyectos de Google Cloud y es inmutable (no se puede cambiar después de configurarlo). Cloud Console genera automáticamente una string única, que, por lo general, no importa cuál sea. En la mayoría de los codelabs, debes hacer referencia al ID del proyecto (suele ser
PROJECT_ID
). Por lo tanto, si no te gusta, genera otro aleatorio o prueba con uno propio y comprueba si está disponible. Después de crear el proyecto, este ID se “congela” y no se puede cambiar. - Además, hay un tercer valor, el Número de proyecto, que usan algunas API. Obtén más información sobre estos tres valores en la documentación.
- A continuación, deberás habilitar la facturación en Cloud Console para usar las API o los recursos de Cloud. Ejecutar este codelab no debería costar mucho, tal vez nada. Si quieres cerrar los recursos para no se te facture más allá de este instructivo, sigue las instrucciones de “limpieza” que se encuentran al final del codelab. Los usuarios nuevos de Google Cloud son aptos para participar en el programa Prueba gratuita de USD 300.
3. Habilita la API de Translation
Habilita las APIs de Cloud
En esta sección, aprenderás a habilitar las APIs de Google en general. En nuestra app de ejemplo, habilitarás la API de Cloud Translation, Cloud Run y Cloud Artifact Registry.
Introducción
Independientemente de la API de Google que quieras usar en tu aplicación, esta debe estar habilitada. En el siguiente ejemplo, se muestran dos maneras de habilitar la API de Cloud Vision. Después de aprender a habilitar una API de Cloud, podrás habilitar otras, ya que el proceso es similar.
Opción 1: Desde Cloud Shell o tu interfaz de línea de comandos
Si bien es más común habilitar las APIs desde la consola de Cloud, algunos desarrolladores prefieren hacerlo todo desde la línea de comandos. Para ello, debes buscar el "nombre del servicio" de una API. Se parece a una URL: SERVICE_NAME
.googleapis.com
. Puedes encontrar estos datos en el gráfico de productos compatibles o consultarlos de forma programática con la API de Google Discovery.
Con esta información, puedes habilitar una API con Cloud Shell (o tu entorno de desarrollo local con la herramienta de línea de comandos de gcloud
instalada) de la siguiente manera:
gcloud services enable SERVICE_NAME.googleapis.com
Por ejemplo, este comando habilita la API de Cloud Vision:
gcloud services enable vision.googleapis.com
Este comando habilita App Engine:
gcloud services enable appengine.googleapis.com
También puedes habilitar varias APIs con una solicitud. Por ejemplo, esta línea de comandos habilita Cloud Run, Artifact Registry de Cloud y la API de Cloud Translation:
gcloud services enable artifactregistry.googleapis.com run.googleapis.com translate.googleapis.com
Opción 2: Desde la consola de Cloud
También puedes habilitar la API de Vision en el Administrador de APIs. En Cloud Console, ve a Administrador de APIs y selecciona Biblioteca.
Si quieres habilitar la API de Cloud Vision, comienza a escribir “visión” en la barra de búsqueda y aparecerá todo lo que coincida con lo que ingresaste hasta el momento:
Selecciona la API que deseas habilitar y haz clic en Habilitar:
Costo
Si bien muchas APIs de Google se pueden usar sin tarifas, el uso de los productos y las APIs de Google Cloud no es gratuito. Cuando habilites las APIs de Cloud, es posible que se te solicite una cuenta de facturación activa. Sin embargo, es importante tener en cuenta que algunos productos de Google Cloud cuentan con un nivel "Siempre gratis" (diario o mensual) que debes superar para generar cargos de facturación. De lo contrario, no se te cobrará a tu tarjeta de crédito (o instrumento de facturación especificado).
Los usuarios deben consultar la información de precios de cualquier API antes de habilitarla, en especial, si tiene un nivel gratuito y, de ser así, cuál es. Si habilitaras la API de Cloud Vision, deberías consultar la página Información de precios. Cloud Vision tiene una cuota gratuita y, siempre que no superes los límites en total (dentro de cada mes), no deberías incurrir en ningún cargo.
Los precios y los niveles gratuitos varían según las APIs de Google. Ejemplos:
- Google Cloud/GCP: Cada producto se factura de forma diferente y, por lo general, se paga por ciclo de vCPU, consumidor de almacenamiento, uso de memoria o pago por uso. Consulta la información del nivel gratuito anterior.
- Google Maps: Incluye un paquete de APIs y ofrece a los usuarios un crédito mensual gratuito de USD 200 en total.
- APIs de Google Workspace (anteriormente G Suite): Proporcionan uso gratuito (hasta ciertos límites) cubierto por una tarifa de suscripción mensual a Workspace, por lo que no hay facturación directa por el uso de las APIs de Gmail, Google Drive, Calendario, Documentos, Hojas de cálculo y Presentaciones.
Los diferentes productos de Google se facturan de manera diferente, así que asegúrate de consultar la documentación de tu API para obtener esa información.
Resumen
Ahora que sabes cómo habilitar las APIs de Google en general, ve al Administrador de APIs y habilita la API de Cloud Translation, Cloud Run y Cloud Artifact Registry (si aún no lo hiciste). Habilitas el primero porque nuestra aplicación lo usa. Habilitas la última opción porque es allí donde se almacenan nuestras imágenes de contenedor antes de implementarse para iniciar tu servicio de Cloud Run, por lo que debes habilitar eso. Si prefieres habilitarlos todos con la herramienta gcloud
, emite el siguiente comando desde la terminal:
gcloud services enable artifactregistry.googleapis.com run.googleapis.com translate.googleapis.com
Si bien su cuota mensual no se indica en la página de resumen general del nivel "Siempre gratis", la página de precios de la API de Translation indica que todos los usuarios obtienen una cantidad fija de caracteres traducidos mensualmente. No deberías incurrir en ningún cargo de la API si te mantienes por debajo de ese límite. Si hay otros cargos relacionados con Google Cloud, se analizarán al final en la sección "Limpieza".
4. Obtén el código de la app de ejemplo
Clona el código en el repositorio de forma local o en Cloud Shell (con el comando git clone
) o descarga el archivo ZIP desde el botón verde Code, como se muestra en la siguiente captura de pantalla:
Ahora que tienes todo, crea una copia completa de la carpeta para realizar este instructivo específico, ya que es probable que debas borrar o cambiar los archivos. Si quieres realizar una implementación diferente, puedes comenzar de nuevo copiando el original para no tener que clonarlo ni volver a descargarlo.
5. Recorrido por la app de ejemplo
La app de ejemplo es una derivación simple de Google Traductor que les solicita a los usuarios que ingresen texto en inglés y reciban la traducción equivalente en español. Ahora abre el archivo main.py
para que podamos ver cómo funciona. Si se omiten las líneas comentadas sobre las licencias, se ve de la siguiente manera en la parte superior y en la inferior:
from flask import Flask, render_template, request
import google.auth
from google.cloud import translate
app = Flask(__name__)
_, PROJECT_ID = google.auth.default()
TRANSLATE = translate.TranslationServiceClient()
PARENT = 'projects/{}'.format(PROJECT_ID)
SOURCE, TARGET = ('en', 'English'), ('es', 'Spanish')
# . . . [translate() function definition] . . .
if __name__ == '__main__':
import os
app.run(debug=True, threaded=True, host='0.0.0.0',
port=int(os.environ.get('PORT', 8080)))
- Las importaciones incluyen la funcionalidad de Flask, el módulo
google.auth
y la biblioteca cliente de la API de Cloud Translation. - Las variables globales representan la app de Flask, el ID del proyecto de Cloud, el cliente de la API de Translation, la "ruta de ubicación" superior para las llamadas a la API de Translation y los idiomas de origen y destino. En este caso, son inglés (
en
) y español (es
), pero no dudes en cambiar estos valores a otros códigos de idioma compatibles con la API de Cloud Translation. - El gran bloque
if
que se encuentra en la parte inferior se usa en el instructivo para ejecutar esta app de forma local. Utiliza el servidor de desarrollo de Flask para entregar nuestra app. Esta sección también está aquí para los instructivos de implementación de Cloud Run en caso de que el servidor web no esté incluido en el contenedor. Se te solicita que habilites el empaquetado del servidor en el contenedor, pero, en caso de que lo pases por alto, el código de la app volverá a usar el servidor de desarrollo de Flask. (No es un problema con App Engine o Cloud Functions, ya que son plataformas basadas en fuentes, lo que significa que Google Cloud proporciona y ejecuta un servidor web predeterminado).
Por último, en el medio de main.py
, se encuentra el corazón de la aplicación, la función translate()
:
@app.route('/', methods=['GET', 'POST'])
def translate(gcf_request=None):
"""
main handler - show form and possibly previous translation
"""
# Flask Request object passed in for Cloud Functions
# (use gcf_request for GCF but flask.request otherwise)
local_request = gcf_request if gcf_request else request
# reset all variables (GET)
text = translated = None
# if there is data to process (POST)
if local_request.method == 'POST':
text = local_request.form['text']
data = {
'contents': [text],
'parent': PARENT,
'target_language_code': TARGET[0],
}
# handle older call for backwards-compatibility
try:
rsp = TRANSLATE.translate_text(request=data)
except TypeError:
rsp = TRANSLATE.translate_text(**data)
translated = rsp.translations[0].translated_text
# create context & render template
context = {
'orig': {'text': text, 'lc': SOURCE},
'trans': {'text': translated, 'lc': TARGET},
}
return render_template('index.html', **context)
La función principal se encarga de tomar la entrada del usuario y llamar a la API de Translation para realizar el trabajo pesado. Veamos esto con más detalle:
- Verifica si las solicitudes provienen de Cloud Functions con la variable
local_request
. Cloud Functions envía su propio objeto de solicitud de Flask, mientras que todos los demás (que se ejecutan de forma local o se implementan en App Engine o Cloud Run) obtendrán el objeto de solicitud directamente de Flask. - Restablece las variables básicas del formulario. Esto se aplica principalmente a las solicitudes GET, ya que las solicitudes POST tendrán datos que los reemplazarán.
- Si es una solicitud POST, toma el texto que se va a traducir y crea una estructura JSON que represente el requisito de metadatos de la API. Luego, llama a la API y vuelve a una versión anterior de la API si el usuario emplea una biblioteca más antigua.
- Independientemente de esto, da formato a los resultados reales (POST) o sin datos (GET) en el contexto de la plantilla y renderiza.
La parte visual de la aplicación se encuentra en el archivo index.html
de la plantilla. Muestra los resultados traducidos anteriormente (en blanco de lo contrario), seguidos del formulario que solicita algo para traducir:
<!doctype html>
<html><head><title>My Google Translate 1990s</title><body>
<h2>My Google Translate (1990s edition)</h2>
{% if trans['text'] %}
<h4>Previous translation</h4>
<li><b>Original</b>: {{ orig['text'] }} (<i>{{ orig['lc'][0] }}</i>)</li>
<li><b>Translated</b>: {{ trans['text'] }} (<i>{{ trans['lc'][0] }}</i>)</li>
{% endif %}
<h4>Enter <i>{{ orig['lc'][1] }}</i> text to translate to <i>{{ trans['lc'][1] }}</i>:</h4>
<form method="POST"><input name="text"><input type="submit"></form>
</body></html>
6. Implemente el servicio
Ahora puedes implementar tu servicio de traducción en Cloud Run ejecutando este comando:
gcloud run deploy translate --source . --allow-unauthenticated --platform managed
El resultado debería ser el siguiente y proporcionar algunas instrucciones para los próximos pasos:
$ gcloud run deploy translate --source . --allow-unauthenticated --platform managed Please specify a region: [1] asia-east1 [2] asia-east2 . . . (other regions) . . . [28] us-west4 [29] cancel Please enter your numeric choice: REGION_CHOICE To make this the default region, run `gcloud config set run/region REGION`. Deploying from source requires an Artifact Registry repository to store build artifacts. A repository named [cloud-run-source-deploy] in region [REGION] will be created. Do you want to continue (Y/n)? This command is equivalent to running "gcloud builds submit --pack image=[IMAGE] ." and "gcloud run deploy translate --image [IMAGE]" Building . . . and deploying container to Cloud Run service [translate] in project [PROJECT_ID] region [REGION] ✓ Building and deploying... Done. ✓ Creating Container Repository... ✓ Uploading sources... ✓ Building Container... Logs are available at [https://console.cloud.google.com/cloud-build/builds/60e1b 9bb-b991-4b4e-8d8a-HASH?project=PROJECT_NUMBER]. ✓ Creating Revision... ✓ Routing traffic... ✓ Setting IAM Policy... Done. Service [translate] revision [translate-00001-xyz] has been deployed and is serving 100 percent of traffic. Service URL: https://SVC_NAME-HASH-REG_ABBR.a.run.app
Ahora que tu app está disponible en todo el mundo, deberías poder acceder a ella en la URL que contiene el ID de tu proyecto, como se muestra en el resultado de la implementación:
Traduce algo para ver cómo funciona.
7. Conclusión
¡Felicitaciones! Aprendiste a habilitar la API de Cloud Translation, obtener las credenciales necesarias y, además, implementar una app web simple en Python 2 Cloud Run. Puedes obtener más información sobre esta implementación en esta tabla del repositorio.
Limpia
La API de Cloud Translation te permite realizar una cantidad fija de caracteres traducidos por mes de forma gratuita. App Engine también tiene una cuota gratuita, y lo mismo sucede con Cloud Functions y Cloud Run. Se te cobrarán cargos si se supera cualquiera de ellos. Si planeas continuar con el siguiente codelab, no es necesario que cierres la app.
Sin embargo, si aún no estás listo para continuar con el siguiente instructivo o te preocupa que Internet descubra la app que acabas de implementar, inhabilita tu app de App Engine, borra tu función de Cloud Functions o inhabilita tu servicio de Cloud Run para evitar que se apliquen cargos. Cuando estés listo para pasar al siguiente codelab, puedes volver a habilitarla. Por otro lado, si no vas a continuar con esta aplicación o con otros codelabs y quieres borrar todo por completo, puedes cerrar tu proyecto.
Además, la implementación en una plataforma de procesamiento sin servidores de Google Cloud genera costos menores de compilación y almacenamiento. Cloud Build tiene su propia cuota gratuita, al igual que Cloud Storage. Para mayor transparencia, Cloud Build compila la imagen de tu aplicación, que luego se almacena en Cloud Container Registry o Artifact Registry, su sucesor. El almacenamiento de esa imagen consume parte de esa cuota, al igual que la salida de red cuando se transfiere esa imagen al servicio. Sin embargo, es posible que vivas en una región que no tenga un nivel gratuito, por lo que debes tener en cuenta tu uso de almacenamiento para minimizar los posibles costos.
8. Recursos adicionales
En las siguientes secciones, encontrarás material de lectura adicional y ejercicios recomendados para aumentar los conocimientos que obtuviste al completar este instructivo.
Estudio adicional
Ahora que tienes algo de experiencia con la API de Translation, hagamos algunos ejercicios adicionales para desarrollar aún más tus habilidades. Para continuar con tu ruta de aprendizaje, modifica nuestra app de ejemplo para hacer lo siguiente:
- Completa todas las demás ediciones de este codelab para ejecutarlo de forma local o implementarlo en las plataformas de procesamiento sin servidores de Google Cloud (consulta el archivo readme del repositorio).
- Completa este instructivo con otro lenguaje de programación.
- Cambia esta aplicación para admitir diferentes idiomas de origen o destino.
- Actualiza esta aplicación para poder traducir texto a más de un idioma. Cambia el archivo de plantilla para que tenga un menú desplegable de los idiomas de destino compatibles.
Más información
Google App Engine
- Página principal de App Engine
- Documentación de App Engine
- Guía de inicio rápido de App Engine para Python 3
- Cuentas de servicio predeterminadas para App Engine
- Entorno de ejecución de App Engine (estándar) para Python 2
- Entorno de ejecución de App Engine (estándar) para Python 3
- Diferencias entre los entornos de ejecución de Python 2 y 3 de App Engine (estándar)
- Guía de migración de Python 2 a 3 en App Engine (estándar)
Google Cloud Functions
- Página principal de Cloud Functions
- Documentación de Cloud Functions
- Guía de inicio rápido de Cloud Functions para Python
- Cuentas de servicio predeterminadas de Cloud Functions
Google Cloud Run
- Página principal de Cloud Run
- Documentación de Cloud Run
- Guía de inicio rápido de Cloud Run para Python
- Cuentas de servicio predeterminadas para Cloud Run
Google Cloud Buildpacks, Container Registry y Artifact Registry
- Anuncio de Cloud Buildpacks
- Repositorio de Cloud Buildpacks
- Página principal de Cloud Artifact Registry
- Documentación de Cloud Artifact Registry
- Página principal de Cloud Container Registry
- Documentación de Cloud Container Registry
Traducción de Google Cloud y Google ML Kit
- Página principal de Cloud Translation
- Documentación de Cloud Translation
- Página de precios de la API de Translation
- Todas las APIs de "piezas fundamentales" de IA/ML de Cloud
- Google ML Kit (subconjunto de APIs de IA/AA de Cloud para dispositivos móviles)
- API de Google ML Kit Translation
Otros productos o páginas de Google Cloud
- Asistencia de Python en Google Cloud
- Bibliotecas cliente de Google Cloud
- Nivel "Siempre gratis" de Google Cloud
- Toda la documentación de Google Cloud
Python y Flask
Licencia
Este instructivo está bajo la licencia Atribución 2.0 Genérica de Creative Commons, mientras que el código fuente del repositorio está bajo la licencia Apache 2.