Crea una función de Cloud Run con Google Cloud CLI
En esta página, se muestra cómo crear y, también, implementar una función de Cloud Run con Google Cloud CLI.
Antes de comenzar
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Cloud Functions, Cloud Build, Artifact Registry, Cloud Run, and Logging APIs.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Cloud Functions, Cloud Build, Artifact Registry, Cloud Run, and Logging APIs.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
Prepara tu entorno de desarrollo.
Node.js
Python
Go
Java
C#
Ruby
PHP
¿Necesitas un símbolo del sistema? Puedes usar Google Cloud Shell. Google Cloud Shell es un entorno de línea de comandos que ya incluye Google Cloud CLI, por lo que no es necesario que lo instales. Google Cloud CLI también viene preinstalado en las máquinas virtuales de Google Compute Engine.
Obtenga el código de muestra
Clona el repositorio de muestra en tu máquina local:
Node.js
git clone https://github.com/GoogleCloudPlatform/nodejs-docs-samples.git
De manera opcional, puedes descargar la muestra como un archivo zip y extraerla.
Python
git clone https://github.com/GoogleCloudPlatform/python-docs-samples.git
De manera opcional, puedes descargar la muestra como un archivo zip y extraerla.
Go
git clone https://github.com/GoogleCloudPlatform/golang-samples.git
De manera opcional, puedes descargar la muestra como un archivo ZIP y extraerla.
Java
git clone https://github.com/GoogleCloudPlatform/java-docs-samples.git
De manera opcional, puedes descargar la muestra como un archivo ZIP y extraerla.
C#
git clone https://github.com/GoogleCloudPlatform/dotnet-docs-samples.git
De manera opcional, puedes descargar la muestra como un archivo ZIP y extraerla.
Ruby
git clone https://github.com/GoogleCloudPlatform/ruby-docs-samples.git
De manera opcional, puedes descargar la muestra como un archivo ZIP y extraerla.
PHP
git clone https://github.com/GoogleCloudPlatform/php-docs-samples.git
De manera opcional, puedes descargar la muestra como un archivo zip y extraerla.
Ve al directorio que contiene el código de muestra de funciones de Cloud Run:
Node.js
cd nodejs-docs-samples/functions/helloworld/helloworldGet/
Python
cd python-docs-samples/functions/helloworld/
Go
cd golang-samples/functions/functionsv2/helloworld/
Java
cd java-docs-samples/functions/helloworld/helloworld/
C#
cd dotnet-docs-samples/functions/helloworld/HelloWorld/
Ruby
cd ruby-docs-samples/functions/helloworld/get/
PHP
cd php-docs-samples/functions/helloworld_get/
Ve el código de muestra:
Node.js
Python
Go
Java
C#
Ruby
PHP
Implementa la función
Para implementar la función con un activador de HTTP, ejecuta el siguiente comando en el directorio que contiene el código de muestra (o, en el caso de Java, el archivo pom.xml
):
Node.js
gcloud functions deploy nodejs-http-function \ --gen2 \ --runtime=nodejs20 \ --region=REGION
\ --source=. \ --entry-point=helloGET \
--trigger-http
Usa la marca --runtime
para especificar el ID del entorno de ejecución de una versión compatible de Node.js para ejecutar la función.
Python
gcloud functions deploy python-http-function \ --gen2 \ --runtime=python312 \ --region=REGION
\ --source=. \ --entry-point=hello_get \
--trigger-http
Usa la marca --runtime
para especificar el ID de entorno de ejecución de una versión de Python compatible para ejecutar la función.
Go
gcloud functions deploy go-http-function \ --gen2 \ --runtime=go121 \ --region=REGION
\ --source=. \ --entry-point=HelloGet \
--trigger-http
Usa la marca --runtime
para especificar el ID de entorno de ejecución de una versión de Go compatible para ejecutar tu función.
Java
gcloud functions deploy java-http-function \ --gen2 \ --runtime=java17 \ --region=REGION
\ --source=. \ --entry-point=functions.HelloWorld \ --memory=512MB \
--trigger-http
Usa la marca --runtime
para especificar el ID del entorno de ejecución de una versión de Java compatible para ejecutar tu función.
C#
gcloud functions deploy csharp-http-function \ --gen2 \ --runtime=dotnet6 \ --region=REGION
\ --source=. \ --entry-point=HelloWorld.Function \
--trigger-http
Usa la marca --runtime
para especificar el ID del entorno de ejecución de una versión .NET compatible para ejecutar tu función.
Ruby
gcloud functions deploy ruby-http-function \ --gen2 \ --runtime=ruby32 \ --region=REGION
\ --source=. \ --entry-point=hello_get \
--trigger-http
Usa la marca --runtime
para especificar el ID de entorno de ejecución de una versión de Ruby compatible para ejecutar tu función.
PHP
gcloud functions deploy php-http-function \ --gen2 \ --runtime=php82 \ --region=REGION
\ --source=. \ --entry-point=helloGet \
--trigger-http
Usa la marca --runtime
para especificar el ID del entorno de ejecución de una versión de PHP compatible para ejecutar la función.
De forma opcional, puedes usar la marca --allow-unauthenticated
para acceder a la función sin autenticación.
Esto es útil para realizar pruebas, pero no se recomienda usar esta configuración en
producción, a menos que crees una API pública o un sitio web. Además, es
posible que no funcione en tu caso, según la configuración de tu política corporativa. Consulta Autentica para la invocación para obtener detalles sobre cómo invocar una función que requiere autenticación.
Regiones
Debes proporcionar una región cuando
implementes una función de Cloud Run. Consulta Ubicaciones para ver una lista de regiones disponibles. La configuración de gcloud CLI tiene una región predeterminada asociada, pero puedes usar la región compatible que quieras en el comando deploy
.
Para ver la región predeterminada asociada a la configuración de tu gcloud CLI, ejecuta lo siguiente:
gcloud config list
Puedes cambiar la región predeterminada de la siguiente manera:
gcloud config set functions/region REGION
Ten en cuenta que, incluso si implementas tu función en tu región predeterminada, debes incluir la región en la línea de comandos de deploy
.
Activa la función
Cuando la función se termine de implementar, toma nota de la propiedad
url
o búscala con el siguiente comando:Node.js
gcloud functions describe nodejs-http-function --gen2 --region REGION --format="value(url)"
Python
gcloud functions describe python-http-function --gen2 --region REGION --format="value(url)"
Go
gcloud functions describe go-http-function --gen2 --region REGION --format="value(url)"
Java
gcloud functions describe java-http-function --gen2 --region REGION --format="value(url)"
C#
gcloud functions describe csharp-http-function --gen2 --region REGION --format="value(url)"
Ruby
gcloud functions describe ruby-http-function --gen2 --region REGION --format="value(url)"
PHP
gcloud functions describe php-http-function --gen2 --region REGION --format="value(url)"
Después de editar el siguiente comando para usar tu propio URI, ejecútalo para ver un mensaje
Hello World!
:curl -m 70 -X POST URI \ -H "Authorization: Bearer $(gcloud auth print-identity-token)" \ -H "Content-Type: application/json" \ -d '{}'
Borra la función
Para borrar la función de Cloud Run que creaste en este instructivo, ejecuta el siguiente comando:
Node.js
gcloud functions delete nodejs-http-function --gen2 --region REGION
Python
gcloud functions delete python-http-function --gen2 --region REGION
Go
gcloud functions delete go-http-function --gen2 --region REGION
Java
gcloud functions delete java-http-function --gen2 --region REGION
C#
gcloud functions delete csharp-http-function --gen2 --region REGION
Ruby
gcloud functions delete ruby-http-function --gen2 --region REGION
PHP
gcloud functions delete php-http-function --gen2 --region REGION
También puedes borrar funciones de Cloud Run en la consola de Google Cloud.
¿Qué sigue?
- Más información sobre Cloud Run Functions.
- Más información sobre cómo implementar Cloud Run Functions.
- Más información sobre cómo llamar a funciones de Cloud Run Functions.
- Más información sobre cómo supervisar funciones de Cloud Run Functions.
- Más información sobre cómo ejecutar funciones de Cloud Run Functions de forma local.
- Consulta los instructivos más avanzados sobre Cloud Run Functions.