Puoi connetterti a un'istanza Redis da Cloud Run utilizzando il traffico VPC diretto in uscita Accesso VPC serverless.
Configurazione
Se hai già installato Google Cloud CLI e hai creato un database Redis Ad esempio, puoi saltare questi passaggi.
Installa gcloud CLI e inizializza:
gcloud init
Segui la guida rapida. per creare un'istanza Redis. Prendi nota della zona, dell'indirizzo IP e della porta l'istanza Redis.
Prepara il traffico in uscita dalla rete VPC per la configurazione
Per connettersi all'istanza Redis, il servizio Cloud Run deve avere accesso alla rete VPC autorizzata dell'istanza Redis. A abilitare questo accesso, è necessario il traffico VPC diretto in uscita o Connettore di accesso VPC serverless. Confronta i due metodi di traffico in uscita dalla rete.
Per trovare il nome della rete autorizzata dell'istanza Redis, esegui il comando seguente:
gcloud redis instances describe INSTANCE_ID --region REGION --format "value(authorizedNetwork)"
Prendi nota del nome della rete.
Se utilizzi l'accesso VPC serverless, crea un connettore. Assicurati di utilizzare la stessa regione e la stessa rete VPC di quella utilizzata dall'istanza Redis. Prendi nota del nome del connettore.
Applicazione di esempio
Questa applicazione di server HTTP di esempio stabilisce una connessione a un'istanza Redis da un servizio Cloud Run.
Clona il repository per il linguaggio di programmazione scelto ed esplora alla cartella che contiene il codice campione:
Vai
git clone https://github.com/GoogleCloudPlatform/golang-samples
cd golang-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
Questa applicazione di esempio incrementa un contatore Redis ogni volta che l'endpoint /
a cui si accede.
Vai
Questa applicazione utilizza
github.com/gomodule/redigo/redis
di alto profilo. Installalo eseguendo questo comando:
go get github.com/gomodule/redigo/redis
Node.js
Questa applicazione utilizza la classe redis
in maggior dettaglio più avanti
in questo modulo.
Python
Questa applicazione utilizza Flask per il servizio web e il pacchetto redis-py
per comunicare con l'istanza Redis.
Deployment dell'applicazione in Cloud Run
Per eseguire il deployment dell'applicazione:
Copia
Dockerfile
nella directory di origine:cp cloud_run_deployment/Dockerfile .
Crea un'immagine container utilizzando Cloud Build con il comando seguente:
gcloud builds submit --tag gcr.io/PROJECT_ID/visit-count
Eseguire il deployment del container in Cloud Run.
Se utilizzi il traffico VPC diretto in uscita, esegui questo comando:
gcloud run deploy \ --image gcr.io/PROJECT_ID/visit-count \ --platform managed \ --allow-unauthenticated \ --region REGION \ --network NETWORK \ --subnet SUBNET \ --set-env-vars REDISHOST=REDIS_IP,REDISPORT=REDIS_PORT
dove:
PROJECT_ID
è l'ID del tuo progetto Google Cloud.REGION
è la regione in cui l'istanza Redis in cui viene localizzato.NETWORK
è il nome dell'utente autorizzato Rete VPC a cui è collegata l'istanza Redis.SUBNET
è il nome della tua subnet. La subnet deve/26
o superiore. Il traffico VPC diretto in uscita supporta intervalli IPv4 RFC 1918, RFC 6598, e Classe E.REDIS_IP
eREDIS_PORT
sono l'indirizzo IP e il numero di porta dell'istanza Redis.
Se utilizzi un connettore di accesso VPC serverless, esegui seguente comando:
gcloud run deploy \ --image gcr.io/PROJECT_ID/visit-count \ --platform managed \ --allow-unauthenticated \ --region REGION \ --vpc-connector CONNECTOR_NAME \ --set-env-vars REDISHOST=REDIS_IP,REDISPORT=REDIS_PORT
dove:
PROJECT_ID
è l'ID del tuo progetto Google Cloud.REGION
è la regione in cui Connettore di accesso VPC serverless e l'istanza Redis in cui si trovano.CONNECTOR_NAME
è il nome del tuo connettore.REDIS_IP
eREDIS_PORT
sono l'indirizzo IP e il numero di porta dell'istanza Redis.
Al termine del deployment, la riga di comando mostra
l'URL del servizio Cloud Run. Visita questo URL in un browser web
(oppure usa uno strumento come curl
) e controlla l'aumento del conteggio delle istanze Redis
ogni volta che viene visitato il servizio.