Puoi connetterti all'istanza Redis solo dai cluster Google Kubernetes Engine che utilizzano la stessa rete autorizzata dell'istanza Redis.
Configurazione
Se hai già installato Google Cloud CLI e 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.
Preparazione del cluster GKE
Se non hai creato un cluster GKE, creane uno utilizzando i seguenti comandi per Google Cloud CLI:
Specifica il progetto per questa applicazione di esempio in
gcloud
.gcloud config set project [PROJECT_ID]
Imposta la variabile di configurazione della zona di Compute Engine in
gcloud
.gcloud config set compute/zone [ZONE]
Crea un cluster GKE denominato
visitcount-cluster
.gcloud container clusters create visitcount-cluster --num-nodes=3 --enable-ip-alias
Se non hai creato il cluster tramite
gcloud
, utilizza questo comando per recuperare le credenziali del cluster:gcloud container clusters get-credentials [CLUSTER_NAME] --zone [CLUSTER_ZONE] --project [PROJECT_ID]
- CLUSTER_NAME è il nome del tuo cluster GKE.
- CLUSTER_ZONE è la zona in cui si trova il cluster.
- PROJECT_ID è il progetto in cui esistono il cluster e le istanze Redis.
Se il cluster è la versione 1.8 o successive e ha gli alias IP attivi, salta questo passaggio. Se il tuo cluster è la versione 1.7 o precedente oppure se il cluster versione 1.8 o successive non ha gli alias IP abilitati, segui questi passaggi della soluzione alternativa prima di provare a connetterti all'istanza.
Esegui questi comandi, sostituendo RESERVED_IP_RANGE con l'intervallo IP riservato della tua istanza:
git clone https://github.com/bowei/k8s-custom-iptables.git cd k8s-custom-iptables/ TARGETS="RESERVED_IP_RANGE" ./install.sh cd ..
Se non conosci l'intervallo IP riservato della tua istanza, puoi scoprirlo tramite la console (opzioni avanzate) o inserendo questo comando:
gcloud redis instances describe INSTANCE_ID --region=REGION
Per ulteriori informazioni sugli IP alias, inclusa la procedura per creare un cluster con questa impostazione abilitata, consulta la documentazione sugli IP alias.
Applicazione di esempio
Questa applicazione server HTTP di esempio stabilisce una connessione a un'istanza Redis da un cluster Google Kubernetes Engine.
Clona il repository per il linguaggio di programmazione che preferisci e vai alla cartella che contiene il codice campione:
Vai
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 viene eseguito l'accesso all'endpoint /
.
Vai
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
è una servlet web che incrementa
un contatore Redis:
Node.js
Questa applicazione utilizza il modulo redis
.
Python
Questa applicazione utilizza Flask
per il servizio web e il pacchetto redis-py
per comunicare con l'istanza Redis.
Creazione dell'immagine container
Crea ed esegui il push dell'immagine container in Container Registry:
cp gke_deployment/Dockerfile .
export PROJECT_ID="$(gcloud config get-value project -q)"
docker build -t gcr.io/${PROJECT_ID}/visit-counter:v1 .
gcloud docker -- push gcr.io/${PROJECT_ID}/visit-counter:v1
Deployment dell'applicazione in Google Kubernetes Engine
Aggiornagke_deployment/visit-counter.yaml
sostituendo <PROJECT_ID>
con l'ID progetto Google Cloud. Questo file contiene la configurazione per il deployment e il servizio.
Vai
Per evitare di codificare l'IP dell'istanza Redis, puoi creare un ConfigMap redishost:
export REDISHOST_IP=XXX.XXX.XXX.XXX
kubectl create configmap redishost --from-literal=REDISHOST=${REDISHOST_IP}
Verifica la configurazione utilizzando il seguente comando:
kubectl get configmaps redishost -o yaml
Java
Node.js
Per evitare di codificare l'IP dell'istanza Redis, puoi creare un ConfigMap redishost:
export REDISHOST_IP=XXX.XXX.XXX.XXX
kubectl create configmap redishost --from-literal=REDISHOST=${REDISHOST_IP}
Verifica la configurazione utilizzando il seguente comando:
kubectl get configmaps redishost -o yaml
Python
Per evitare di codificare l'IP dell'istanza Redis, puoi creare un ConfigMap redishost:
export REDISHOST_IP=XXX.XXX.XXX.XXX
kubectl create configmap redishost --from-literal=REDISHOST=${REDISHOST_IP}
Verifica la configurazione utilizzando il seguente comando:
kubectl get configmaps redishost -o yaml
Applica la configurazione al cluster:
kubectl apply -f gke_deployment/visit-counter.yaml
Determina l'indirizzo [EXTERNAL-IP] per questa app di esempio eseguendo questo comando:
kubectl get service visit-counter
Visualizza l'app ospitata all'indirizzo http://[EXTERNAL-IP] tramite il browser o invia una richiesta GET tramite cURL o il browser:
curl http://[EXTERNAL-IP]
Rimozione della voce delle tabelle IP per l'istanza Redis
Se hai seguito il passaggio 3 della sezione di questa procedura dettagliata chiamata Preparazione del cluster GKE, hai installato l'intervallo IP riservato della tua istanza Redis nelle tabelle IP della tua istanza GKE. Se vuoi rimuovere questa voce dell'intervallo IP Redis dalle tabelle IP della tua istanza GKE, esegui il comando seguente dalla directory k8s-custom-iptables/
:
./uninstall.sh