Questa pagina descrive come connetterti all'istanza Redis utilizzando Telnet e redis-cli. Inoltre, fornisce istruzioni su come connetterti quando utilizzi funzionalità come le repliche di lettura, AUTH e la crittografia in transito.
Infine, fornisce istruzioni su come connetterti da un ambiente Google Kubernetes Engine.
Per un elenco degli Google Cloud ambienti supportati da Memorystore for Redis, consulta Ambienti supportati. Alcuni ambienti serverless supportati da Memorystore richiedono un connettore di accesso VPC serverless. Per maggiori dettagli, consulta Requisito del connettore di accesso VPC serverless.
Connettersi a un'istanza Redis da una VM di Compute Engine utilizzando telnet
Puoi connetterti all'istanza Memorystore for Redis da qualsiasi VM di Compute Engine che utilizzi la rete autorizzata dell'istanza con un indirizzo IP RFC 1918 supportato.
Se non hai una VM di Compute Engine che utilizza la stessa rete autorizzata dell'istanza, creane una e connettiti alla VM utilizzando SSH. Per farlo, segui i passaggi descritti in Creare un'istanza VM Linux in Compute Engine.
Utilizza
apt-getper installaretelnet:sudo apt-get install telnetNel terminale, inserisci il comando telnet seguito dall'indirizzo IP dell'istanza. Sostituisci VARIABLES con valori appropriati.
telnet INSTANCE_IP_ADDRESS 6379
Se riesci a connetterti all'istanza, il comando restituisce questo risultato:
Trying INSTANCE_IP_ADDRESS… Connected to INSTANCE_IP_ADDRESS
Nella sessione di Telnet, inserisci alcuni comandi Redis:
Digita:
PING
Risultato:
PONG
Invio
SET HELLO WORLD
Risultato:
+OK
Digita:
GET HELLO
Risultato:
$5 WORLD
Connettersi a un'istanza Redis da una VM di Compute Engine utilizzando redis-cli
Puoi connetterti all'istanza Redis da qualsiasi VM di Compute Engine che utilizzi la rete autorizzata dell'istanza Redis con un indirizzo IP RFC 1918 supportato.
Se non hai già una VM di Compute Engine che utilizza la rete autorizzata per l'istanza Redis, creane una e connettiti seguendo la procedura descritta in Creare un'istanza VM in una subnet specifica.
Installa
redis-clisulla VM di Compute Engine eseguendo il seguente comando dal terminale SSH di Compute Engine:sudo apt-get install redis-tools
Esegui il seguente comando nel terminale di Compute Engine, sostituendo variables con valori appropriati.
redis-cli -h redis-instance-ip-address
Ora sei connesso all'istanza Redis utilizzando
redis-cli.Una volta terminato il test della connessione all'istanza Redis, ti consigliamo di eliminare la VM di Compute Engine che hai utilizzato per connetterti all'istanza Redis. In questo modo, eviterai di incorrere in addebiti sul tuo account di fatturazione Cloud.
Connettersi a un'istanza Redis che utilizza AUTH
Questa sezione descrive come connetterti a un'istanza Redis con la funzionalità AUTH abilitata.
Se non hai già una VM di Compute Engine che utilizza la stessa rete autorizzata dell'istanza Redis, creane una e connettiti seguendo la Guida rapida all'utilizzo di una VM Linux.
Installa
redis-clisulla VM di Compute Engine eseguendo il seguente comando dal terminale SSH di Compute Engine:sudo apt-get install redis-tools
Recupera la stringa AUTH dell'istanza
Esegui il seguente comando per utilizzare
redis-cliper autenticare e connetterti a l'istanza, sostituendo variables con valori appropriati:redis-cli -h instance-ip-address -a auth-string
Oppure:
redis-cli -h instance-ip-address AUTH auth-string
Esegui un comando Redis
SETeGETper verificare di aver stabilito una connessione autenticata all'istanza.Una volta terminato il test della connessione all'istanza Redis, ti consigliamo di eliminare la VM di Compute Engine che hai utilizzato per connetterti all'istanza Redis. In questo modo, eviterai di incorrere in addebiti sul tuo account di fatturazione Cloud.
Connettersi a un'istanza Redis utilizzando l'endpoint di lettura
Se la tua istanza ha le repliche di lettura abilitate, puoi connetterti all'endpoint di lettura seguendo queste istruzioni:
Se non hai già una VM di Compute Engine che utilizza la stessa rete autorizzata dell'istanza Redis, creane una e connettiti seguendo la Guida rapida all'utilizzo di una VM Linux.
Installa
telnetutilizzandoapt-get:sudo apt-get install telnetPer trovare l'indirizzo IP dell'endpoint di lettura dell'istanza, visualizza le informazioni sulla replica di lettura per l'istanza.
Nel terminale, inserisci il comando telnet seguito dall'indirizzo IP dell'endpoint di lettura dell'istanza Redis, sostituendo variables con valori appropriati.
telnet read-endpoint-ip 6379
In caso di esito positivo, il comando restituirà questo risultato:
Trying read-endpoint-ip… Connected to read-endpoint-ip
Nella sessione di Telnet, inserisci alcuni comandi Redis:
Digita:
PING
Risultato:
PONG
Connettersi a un'istanza Redis in modo sicuro utilizzando Stunnel e telnet
Questa sezione fornisce un esempio di come connetterti a un'istanza Redis con la crittografia in transito abilitata utilizzando Stunnel.
Se non hai già un'istanza Redis con la crittografia in transito abilitata, creane una seguendo la procedura descritta in Creare un'istanza Redis con la crittografia in transito.
Se non hai già una VM di Compute Engine che utilizza la stessa rete autorizzata dell'istanza Redis del passaggio precedente, creane una e connettiti seguendo la Guida rapida all'utilizzo di una VM Linux.
Installa gli strumenti necessari per questa guida eseguendo i seguenti comandi:
sudo apt-get install stunnel4
sudo apt-get install telnet
Configura la VM di Compute Engine per l'utilizzo con Stunnel:
Crea un nuovo file in cui inserire l'autorità di certificazione (CA) eseguendo il seguente comando:
sudo vim /tmp/server_ca.pem
Visualizza le autorità di certificazione dell'istanza Redis eseguendo il seguente comando nel terminale standard che utilizzi per gestire Google Cloud risorse (non il terminale di Compute Engine):
gcloud redis instances describe instance-id --region=region
Possono essere presenti fino a tre CA.
Copia tutte le autorità di certificazione visibili, incluse le righe
-----BEGIN CERTIFICATE-----e-----END CERTIFICATE-----, incollale e salvale nel fileserver_ca.pemche hai creato in precedenza.Crea un nuovo file in cui inserire le informazioni di configurazione di Stunnel eseguendo il seguente comando:
sudo vim /etc/stunnel/redis-client.conf
Incolla il seguente testo nel file, sostituendo redis-instance-ip con l'indirizzo IP dell'istanza Redis:
output=/tmp/stunnel.log CAfile=/tmp/server_ca.pem client=yes pid=/var/run/stunnel.pid verifyChain=yes sslVersion=TLSv1.2 [redis] accept=127.0.0.1:6378 connect=redis-instance-ip:6378
Avvia stunnel eseguendo il seguente comando:
sudo stunnel /etc/stunnel/redis-client.conf
Verifica che stunnel sia in esecuzione:
ps aux | grep stunnel
Riavvia Stunnel eseguendo i seguenti comandi:
sudo systemctl restart stunnel4
Per connetterti all'istanza Redis utilizzando Telnet, esegui il seguente comando:
telnet localhost 6378
Nella sessione di Telnet, esegui il ping dell'istanza Redis:
Digita:
PING
Risultato:
PONG
Connettersi da una macchina locale utilizzando l'inoltro delle porte
Può essere utile connetterti all'istanza Redis dalla tua macchina locale durante lo sviluppo. Per farlo, devi creare un'istanza di Compute Engine da utilizzare per l'inoltro delle porte all'istanza Redis.
Crea un'istanza di Compute Engine eseguendo il seguente comando:
gcloud compute instances create COMPUTE_VM_NAME --machine-type=f1-micro --zone=ZONE
Dove:
- COMPUTE_VM_NAME è il nome che assegni alla VM di Compute Engine.
- ZONE è la zona in cui vuoi eseguire il provisioning della VM.
Questo comando crea una VM di Compute Engine con il
f1-microtipo di macchina per la convenienza. Puoi scegliere altri tipi di macchine.Apri un nuovo terminale sulla macchina locale.
Per creare un tunnel SSH che inoltri il traffico tramite la VM di Compute Engine, esegui il seguente comando:
gcloud compute ssh COMPUTE_VM_NAME --zone=ZONE -- -N -L 6379:REDIS_INSTANCE_IP_ADDRESS:6379
Dove:
- COMPUTE_VM_NAME è il nome della VM di Compute Engine.
- ZONE è la stessa zona in cui si trova la VM di Compute Engine.
- REDIS_INSTANCE_IP_ADDRESS è l'indirizzo IP dell'istanza Redis.
Per testare la connessione, apri una nuova finestra del terminale ed esegui il seguente comando:
redis-cli ping
Se funziona correttamente, il risultato dovrebbe essere:
PONG
Ora sei connesso all'istanza Redis e puoi inviare comandi all'istanza Redis utilizzando questo tunnel SSH aperto. Se non hai ancora installato
redis-cli, installalo per poter eseguire questo comando.Il tunnel SSH rimane aperto finché la finestra del terminale con la connessione del tunnel SSH è attiva e in esecuzione.
Connettersi a un'istanza Redis da un cluster Google Kubernetes Engine
Per verificare se il cluster utilizza gli alias IP, utilizza gcloud container clusters describe.
Puoi connetterti all'istanza Redis dai cluster Google Kubernetes Engine che utilizzano la stessa rete autorizzata dell'istanza Redis.
Connettersi da un pod che esegue una shell bash
- Vai alla pagina GKE nella Google Cloud console.
GKE - Fai clic sul cluster GKE da cui vuoi connetterti. Se non hai già un cluster, creane uno con gli alias IP abilitati. Per istruzioni su come creare un cluster con gli alias IP abilitati, consulta Creare un cluster nativo di VPC.
- Fai clic sul pulsante Connetti a destra del nome del cluster, quindi fai clic sul pulsante Esegui in Cloud Shell nella finestra visualizzata.
- Configura l'accesso alla riga di comando
kubectleseguendo il seguente comando:gcloud container clusters get-credentials CLUSTER_NAME --zone=CLUSTER_ZONE --project=PROJECT_ID
CLUSTER_NAMEè il nome del cluster.CLUSTER_ZONEè la zona in cui si trova il cluster. Deve essere anche la zona in cui si trova l'istanza Redis.PROJECT_IDè il progetto in cui esistono il cluster e le istanze Redis.
kubeconfig generated for CLUSTER_NAME - Se il cluster è la versione 1.8 o successive e ha gli alias IP abilitati, salta questo passaggio. Se il cluster è la versione 1.7 o precedenti oppure il cluster della versione 1.8 o successive non ha gli alias IP abilitati, segui questi passaggi di soluzione alternativa prima di provare a connetterti all'istanza: Per ulteriori informazioni sugli alias IP, inclusa la procedura per creare un cluster con questa impostazione abilitata, consulta Creare un cluster nativo di VPC.
- Utilizza il seguente comando per connetterti a una shell bash:
kubectl run -i --tty busybox --image=busybox -- sh
- Inserisci il comando telnet seguito dall'indirizzo host e dal numero di porta dell'istanza Redis:
telnet HOST-IP PORT
- Inserisci un comando Redis di base per verificare la connessione:
PING +PONG
- Per chiudere la connessione telnet, premi CTRL+C (o Comando+C su Mac). Per uscire dalla shell bash nel pod, premi Invio. Se hai finito e non hai più bisogno di connetterti a Redis, esegui il seguente comando dalla
/k8s-custom-iptables/directory:./uninstall.sh
Connettersi a un'istanza Redis da un pod Google Kubernetes Engine
Prima di iniziare, devi avere un cluster GKE. Se non hai già un cluster, creane uno con gli alias IP abilitati. Per istruzioni su come creare un cluster con gli alias IP abilitati, consulta Creare un cluster nativo di VPC.
- Nell'angolo in alto a destra della console, fai clic sul pulsante Attiva Cloud Shell
. - Configura l'accesso alla riga di comando
kubectleseguendo il seguente comando:gcloud container clusters get-credentials CLUSTER_NAME --zone CLUSTER_ZONE --project PROJECT_ID
CLUSTER_NAMEè il nome del cluster.CLUSTER_ZONEè la zona in cui si trova il cluster. Deve essere anche la zona in cui si trova l'istanza Redis.PROJECT_IDè il progetto in cui esistono il cluster e le istanze Redis.
kubeconfig generated for CLUSTER_NAME - Se il cluster è la versione 1.8 o successive e ha gli alias IP abilitati, salta questo passaggio. Se il cluster è la versione 1.7 o precedenti oppure il cluster della versione 1.8 o successive non ha gli alias IP abilitati, segui questi passaggi di soluzione alternativa prima di provare a connetterti all'istanza: Per ulteriori informazioni sugli alias IP, inclusa la procedura per creare un cluster con questa impostazione abilitata, consulta Creare un cluster nativo di VPC.
- Utilizza il seguente comando per avviare un pod Redis che esegue
redis-cli:kubectl run -i --tty redisbox --image=redis:7.2 -- sh
- Esegui un comando
redis-cli, sostituendoHOST-IPcon l'indirizzo IP host dell'istanza Redis:redis-cli -h HOST-IP info
- Facoltativamente, esegui un benchmark Redis command, sostituendo di nuovo
HOST-IPcon l'indirizzo IP host dell'istanza Redis:redis-benchmark -c 100 -n 100000 -d 1024 -r 100000 -t PING,SET,GET,INCR,LPUSH,RPUSH,LPOP,RPOP,SADD,SPOP,MSET -h HOST-IP -q
- Per uscire dal pod Redis, premi
return. Se hai finito e non hai più bisogno di connetterti a Redis, esegui il seguente comando dalla directory/k8s-custom-iptables/:./uninstall.sh
Passaggi successivi
Connettiti all'istanza Redis utilizzando un'applicazione di esempio in esecuzione su:
- Compute Engine
- GKE
- Cloud Run
- Ambiente standard di App Engine
- Ambiente flessibile di App Engine
- Cloud Run Functions