Puedes conectarte a una instancia de Redis desde Cloud Run usando 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 initSigue 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 el tráfico de salida de la red de VPC para la configuración
Para conectarte a tu instancia de Redis, tu servicio 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.
Aplicación de ejemplo
Esta aplicación del servidor HTTP de muestra establece una conexión con una instancia de Redis desde un servicio de Cloud Run.
Clona el repositorio de tu lenguaje de programación elegido y navega a la carpeta que contiene el código de muestra:
Go
git clone https://github.com/GoogleCloudPlatform/golang-samples
cd golang-samples/memorystore/redis
Java
git clone https://github.com/GoogleCloudPlatform/java-docs-samples
cd java-docs-samples/memorystore/redis
Node.js
git clone https://github.com/GoogleCloudPlatform/nodejs-docs-samples
cd nodejs-docs-samples/memorystore/redis
Python
git clone https://github.com/GoogleCloudPlatform/python-docs-samples
cd python-docs-samples/memorystore/redis
Esta aplicación de muestra aumenta un contador de Redis cada vez que se accede al extremo /.
Go
En esta aplicación, se usa el cliente github.com/gomodule/redigo/redis. Para instalarla, ejecuta el siguiente comando:
go get github.com/gomodule/redigo/redis@latest
Aplicación de ejemplo:
Java
Esta aplicación se basa en el servlet Jetty 3.1.
Usa la biblioteca de Jedis:
La clase AppServletContextListener se usa para crear un grupo de conexiones de Redis de larga duración:
La clase VisitCounterServlet es un servlet web que incrementa un contador de Redis.
Node.js
En esta aplicación, se usa el módulo redis. Este es un archivo package.json de ejemplo:
Código de la aplicación de ejemplo:
Python
Esta aplicación usa Flask para la entrega web y el paquete redis-py a fin de comunicarse con la instancia de Redis.
Código de la aplicación de ejemplo:
Implementa la aplicación en Cloud Run
Para implementar la aplicación, haz lo siguiente:
Copia el archivo
Dockerfileen el directorio fuente:cp cloud_run_deployment/Dockerfile .Ejecuta el siguiente comando para compilar una imagen de contenedor con Cloud Build:
gcloud artifacts repositories create --location REPO_REGION --repository-format=docker REPO_ID gcloud builds submit --pack image=REPO_REGION-docker.pkg.dev/PROJECT_ID/REPO_ID/visit-counter:v1
Ejecuta el siguiente comando para implementar el contenedor en Cloud Run:
gcloud run deploy \ --image REPO_REGION-docker.pkg.dev/PROJECT_ID/REPO_ID/visit-counter:v1 \ --allow-unauthenticated \ --region REGION \ --network NETWORK \ --subnet SUBNET \ --set-env-vars REDISHOST=REDIS_IP,REDISPORT=REDIS_PORT
Donde:
REPO_REGIONes la región del repositorio.REPO_IDes el nombre del repositorio que contiene la imagen de la aplicación.PROJECT_IDes el ID de tu proyecto de Google Cloud .REGIONes la región en la que se encuentra tu instancia de Redis.NETWORKes el nombre de la red de VPC autorizada a la que está conectada tu instancia de Redis.SUBNETes el nombre de la subred. La subred debe ser/26o mayor. La salida de VPC directa es compatible con los rangos IPv4 RFC 1918, RFC 6598 y clase E.REDIS_IPyREDIS_PORTson la dirección IP y el número de puerto de tu instancia de Redis.
Una vez que la implementación se complete de forma correcta, la línea de comandos mostrará la URL de tu servicio de Cloud Run. Visita esta URL en un navegador web (o usa una herramienta como curl) y observa que el recuento en tu instancia de Redis aumenta cada vez que se visita el servicio.