Puoi connetterti a un'istanza Redis dall'ambiente standard App Engine utilizzando l'accesso VPC serverless.
Configurazione
Se hai già installato Google Cloud CLI e hai creato un'istanza Redis, 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 dell'istanza Redis.
Configurazione dell'accesso VPC serverless
Per connetterti dall'app App Engine alla rete VPC autorizzata dell'istanza Redis, devi configurare l'accesso VPC serverless.
Trova la rete autorizzata dell'istanza Redis eseguendo il comando:
gcloud beta redis instances describe [INSTANCE_ID] --region [REGION]
Segui le istruzioni sulla creazione di un connettore per creare un connettore di accesso VPC serverless. Assicurati di creare il connettore nella stessa regione dell'app e che il connettore sia collegato alla rete VPC autorizzata dell'istanza Redis. Ricorda il nome del connettore.
Applicazione di esempio
Questa applicazione server HTTP di esempio stabilisce una connessione a un'istanza Redis da un'app dell'ambiente standard di App Engine.
Clona il repository per il linguaggio di programmazione desiderato e vai alla cartella che contiene il codice campione:
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
Questa applicazione di esempio incrementa un contatore Redis ogni volta che si accede all'endpoint /
.
Go
Questa applicazione utilizza il client github.com/gomodule/redigo/redis
. Installalo eseguendo questo comando:
go get github.com/gomodule/redigo/redis
Java
Questa applicazione è basata su servlet Jetty 3.1.
Utilizza la libreria Jedis:
La classe AppServletContextListener
viene utilizzata per creare un pool di connessioni Redis di lunga durata:
La classe VisitCounterServlet
è un servlet web che incrementa un contatore Redis:
Node.js
Questa applicazione utilizza il modulo redis
.
Python
Questa applicazione utilizza Flask per la pubblicazione web e il pacchetto redis-py
per comunicare con l'istanza Redis.
Preparazione dell'applicazione per il deployment
Per accedere all'istanza Redis, l'app App Engine deve essere configurata in modo da utilizzare il connettore di accesso VPC serverless e devi fornire i dettagli della connessione dell'istanza Redis.
Se non ne hai già una, crea un'applicazione App Engine.
Aggiorna la configurazione dell'app per specificare il connettore di accesso VPC serverless, nonché l'indirizzo IP e la porta dell'istanza Redis:
Go
Aggiorna il file
gae_standard_deployment/app.yaml
:Vedi File di configurazione app.yaml per ulteriori dettagli.
Java
Aggiorna il file
gae_standard_deployment/appengine-web.xml
per specificare il tuo connettore di accesso VPC serverless:Aggiorna il file
src/main/resources/application.properties
con l'indirizzo IP e la porta dell'istanza Redis:Per ulteriori informazioni sulla configurazione dell'app, consulta la documentazione di riferimento di appengine-web.xml.
Node.js
Aggiorna il file
gae_standard_deployment/app.yaml
:Vedi File di configurazione app.yaml per ulteriori dettagli.
Python
Aggiorna il file
gae_standard_deployment/app.yaml
:Vedi File di configurazione app.yaml per ulteriori dettagli.
Deployment dell'applicazione nell'ambiente standard di App Engine
Per eseguire il deployment dell'applicazione:
Copia i file di configurazione necessari nella directory di origine:
Go
Copia i file
app.yaml
ego.mod
nella directory di origine:cp gae_standard_deployment/{app.yaml,go.mod} .
Java
Copia il file
appengine-web.xml
nella directory di origine:mkdir -p src/main/webapp/WEB-INF cp gae_standard_deployment/appengine-web.xml src/main/webapp/WEB-INF/
Node.js
Copia il file
app.yaml
nella directory di origine:cp gae_standard_deployment/app.yaml .
Python
Copia il file
app.yaml
nella directory di origine:cp gae_standard_deployment/app.yaml .
Esegui il comando di deployment:
Go
gcloud app deploy
Java
mvn package appengine:stage gcloud app deploy target/appengine-staging/app.yaml
Node.js
gcloud app deploy
Python
gcloud app deploy
Al termine del deployment, il comando restituirà l'URL da cui puoi visitare l'app. Se visiti questo URL, vedrai un aumento del conteggio sull'istanza Redis ogni volta che la pagina viene caricata.