Vous pouvez vous connecter à une instance Redis depuis Cloud Run Functions à l'aide de la sortie VPC directe.
Configuration
Si vous avez déjà installé Google Cloud CLI et créé une instance Redis, vous pouvez ignorer ces étapes.
Installez la gcloud CLI et initialisez-la :
gcloud init
Suivez le Guide de démarrage rapide pour créer une instance Redis. Retenez la zone, l'adresse IP et le port de l'instance Redis.
Préparer la sortie réseau VPC pour la configuration
Pour se connecter à votre instance Redis, votre fonction Cloud Run doit avoir accès au réseau VPC autorisé de votre instance Redis.
Pour trouver le nom de ce réseau, exécutez la commande suivante :
gcloud redis instances describe INSTANCE_ID --region REGION --format "value(authorizedNetwork)"
Notez le nom du réseau.
Exemple de fonction
Cet exemple de fonction établit une connexion à une instance Redis à partir de Cloud Run Functions.
Clonez le dépôt correspondant au langage de programmation souhaité et accédez au dossier contenant l'exemple de code :
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
L'exemple de code incrémente un compteur Redis chaque fois que la fonction est déclenchée :
Go
Cette fonction utilise le client github.com/gomodule/redigo/redis
.
Node.js
Cette fonction utilise le module redis
.
Python
Cette fonction utilise le package redis-py
.
Déployer l'exemple sur les fonctions Cloud Run
Pour déployer la fonction, procédez comme suit :
Copiez le fichier
Dockerfile
dans le répertoire source :cp cloud_run_deployment/Dockerfile .
Créez une image de conteneur à l'aide de Cloud Build en exécutant la commande suivante :
gcloud builds submit --tag gcr.io/PROJECT_ID/visit-count
Déployez le conteneur sur Cloud Run en exécutant la commande suivante :
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
où :
PROJECT_ID
est l'ID de votre projet Google Cloud .REGION
est la région dans laquelle se trouve votre instance Redis.NETWORK
est le nom du réseau VPC autorisé auquel votre instance Redis est associée.SUBNET
est le nom de votre sous-réseau. Le sous-réseau doit être/26
ou supérieur. La sortie VPC directe est compatible avec les plages IPv4 RFC 1918, RFC 6598 et de classe E.REDIS_IP
etREDIS_PORT
sont l'adresse IP et le numéro de port de votre instance Redis.
Une fois le déploiement de la fonction terminé, récupérez son URL :
gcloud run services describe visit-count \ --region=REGION
Vous pouvez voir le compteur augmenter chaque fois que vous déclenchez la fonction en envoyant une requête GET
à son URL.