Puedes conectarte a una instancia de Redis desde Cloud Run Functions a través de la salida de VPC directa.
Configuración
Si ya instalaste Google Cloud CLI y creaste una instancia de Redis, puedes omitir estos pasos.
Instala la CLI de gcloud y, luego, inicialízala:
gcloud init
Sigue la Guía de inicio rápido para crear una instancia de Redis. Anota la zona, la dirección IP y el puerto de la instancia de Redis.
Prepara la salida de la red de VPC para la configuración
Para conectarte a tu instancia de Redis, tu función de Cloud Run debe tener acceso a la red de VPC autorizada de la instancia de Redis.
Para encontrar el nombre de esta red, ejecuta el siguiente comando:
gcloud redis instances describe INSTANCE_ID --region REGION --format "value(authorizedNetwork)"
Toma nota del nombre de la red.
Función de muestra
Esta función de muestra establece una conexión con una instancia de Redis desde Cloud Run Functions.
Clona el repositorio de tu lenguaje de programación deseado y navega a la carpeta que contiene el código de muestra:
Go
git clone https://github.com/GoogleCloudPlatform/golang-samples
cd golang-samples/functions/memorystore/redis
Node.js
git clone https://github.com/GoogleCloudPlatform/nodejs-docs-samples
cd nodejs-docs-samples/functions/memorystore/redis
Python
git clone https://github.com/GoogleCloudPlatform/python-docs-samples
cd python-docs-samples/functions/memorystore/redis
El código de muestra incrementa un contador de Redis cada vez que se activa la función:
Go
En esta función, se usa el cliente github.com/gomodule/redigo/redis
.
Node.js
En esta función, se usa el módulo redis
.
Python
En esta función, se usa el paquete redis-py
.
Implementa la muestra en Cloud Run Functions
Sigue estos pasos para implementar la función:
Copia el archivo
Dockerfile
en el directorio fuente:cp cloud_run_deployment/Dockerfile .
Ejecuta el siguiente comando para compilar una imagen de contenedor con Cloud Build:
gcloud builds submit --tag gcr.io/PROJECT_ID/visit-count
Ejecuta el siguiente comando para implementar el contenedor en Cloud Run:
gcloud run deploy \ --image gcr.io/PROJECT_ID/visit-count \ --allow-unauthenticated \ --region REGION \ --network NETWORK \ --subnet SUBNET \ --set-env-vars REDISHOST=REDIS_IP,REDISPORT=REDIS_PORT
Donde:
PROJECT_ID
es el ID de tu proyecto de Google Cloud .REGION
es la región en la que se encuentra tu instancia de Redis.NETWORK
es el nombre de la red de VPC autorizada a la que está conectada tu instancia de Redis.SUBNET
es el nombre de la subred. La subred debe ser/26
o mayor. La salida de VPC directa admite los rangos IPv4 RFC 1918, RFC 6598 y clase E.REDIS_IP
yREDIS_PORT
son la dirección IP y el número de puerto de tu instancia de Redis.
Cuando finalice la implementación de la función, recupera su URL:
gcloud run services describe visit-count \ --region=REGION
Puedes ver cómo aumenta el contador cada vez que activas la función enviando una solicitud GET
a su URL.