Questo tutorial mostra come gestire le sessioni su Cloud Run.
Molte app richiedono la gestione delle sessioni per l'autenticazione e le preferenze dell'utente. Il framework Jetty include un'implementazione basata sulla memoria per eseguire questa funzione. Tuttavia, questa implementazione non è adatta per un'app che può essere pubblicata da più istanze, perché la sessione registrata in un'istanza potrebbe essere diversa da altre istanze. Questo tutorial mostra come gestire le sessioni su Cloud Run.
Obiettivi
- Scrivi l'app.
- Esegui l'app localmente.
- Esegui il deployment dell'app su Cloud Run.
Costi
In questo documento utilizzi i seguenti componenti fatturabili di Google Cloud:
Per generare una stima dei costi in base all'utilizzo previsto,
utilizza il Calcolatore prezzi.
Al termine delle attività descritte in questo documento, puoi evitare la fatturazione continua eliminando le risorse che hai creato. Per ulteriori informazioni, consulta la sezione Pulizia.
Prima di iniziare
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Firestore API.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the Firestore API.
-
In Google Cloud Console, apri l'app in Cloud Shell.
Cloud Shell fornisce l'accesso tramite riga di comando alle tue risorse cloud direttamente dal browser. Apri Cloud Shell nel browser e fai clic su Procedi per scaricare il codice di esempio e modificarlo nella directory dell'applicazione.
-
In Cloud Shell, configura l'interfaccia a riga di comando gcloud in modo da utilizzare il tuo nuovo progetto Google Cloud:
# Configure gcloud for your project gcloud config set project YOUR_PROJECT_ID
-
Aggiorna Maven per utilizzare Java 11 per impostazione predefinita:
Quando richiesto, inserisci il numero per selezionare Java 11. Prendi nota del percorso indicato per la versione.sudo update-alternatives --config java
- Esporta il percorso che hai copiato nel passaggio precedente come variabile di ambiente:
export JAVA_HOME=java-11-path
L'app web
Questa app visualizza i saluti in diverse lingue per ogni utente. Gli utenti di ritorno vengono sempre accolti nella stessa lingua.
Prima che la tua app possa memorizzare le preferenze per un utente, devi trovare un modo per memorizzare
le informazioni sull'utente corrente in una sessione. Questa app di esempio utilizza un elemento
WebFilter
per recuperare e aggiornare i dati delle sessioni in Firestore.
Il seguente diagramma illustra il modo in cui Firestore gestisce le sessioni per l'app Cloud Run.
HttpServletRequest
utilizza un cookie per archiviare un ID univoco per la
sessione locale, che corrisponde a un documento in Firestore con
i dettagli della sessione.
Eliminazione di sessioni
Firestore non elimina le sessioni vecchie o scadute. Puoi eliminare i dati della sessione in Google Cloud Console o implementare una strategia di eliminazione automatica. Se utilizzi soluzioni di archiviazione per sessioni quali Memcache o Redis, le sessioni scadute vengono eliminate automaticamente.
Esecuzione in locale
Avvia il server HTTP:
mvn jetty:run
Visualizza l'app nel browser web:
Cloud Shell
Nella barra degli strumenti di Cloud Shell, fai clic su Anteprima web e seleziona Anteprima sulla porta 8080.
Computer locale
Nel browser, vai a
http://localhost:8080
Vedrai uno dei cinque saluti: "Hello World" e "Hallo Welt", "Hola mundo", La lingua cambia se apri la pagina in un altro browser o in modalità di navigazione in incognito. Puoi visualizzare e modificare i dati della sessione in Google Cloud Console.
Per interrompere il server HTTP, premi
Control+C
nella finestra del terminale.
Deployment ed esecuzione in Cloud Run
Puoi utilizzare Cloud Run per creare ed eseguire il deployment di un'app che viene eseguita in modo affidabile con carichi elevati e con grandi quantità di dati.
Nella finestra del terminale, crea ed esegui il deployment di un'immagine del tuo codice in Google Container Registry (GCR) con il plug-in Jib Maven.
mvn clean package jib:build
Esegui il deployment dell'app su Cloud Run:
gcloud beta run deploy session-handling --image gcr.io/MY_PROJECT/session-handling
--platform managed --region us-central1 --memory 512MSostituisci
MY_PROJECT
con l'ID del progetto Cloud che hai creato. Visita l'URL restituito da questo comando per vedere come i dati della sessione persistono tra un caricamento pagina e l'altro.
Esecuzione del debug dell'app
Se non riesci a connetterti all'app Cloud Run, verifica quanto segue:
- Controlla che i comandi di deployment di
gcloud
siano stati completati correttamente e che non abbiano restituito errori. Se si sono verificati errori (ad esempio,message=Build failed
), correggili e prova a eseguire di nuovo il deployment dell'app Cloud Run. In Cloud Console, vai alla pagina Esplora log.
Nell'elenco a discesa Risorse selezionate di recente, fai clic su Applicazione Cloud Run e quindi su All module_id. Viene visualizzato un elenco di richieste da quando hai visitato la tua app. Se non vedrai un elenco di richieste, conferma di aver selezionato All module_id dall'elenco a discesa. Se vengono visualizzati messaggi di errore stampati in Cloud Console, verifica che il codice dell'app corrisponda al codice nella sezione relativa alla scrittura dell'app web.
Assicurati che l'API Firestore sia abilitata.
Esegui la pulizia
Elimina il progetto
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.
Elimina l'istanza Cloud Run
Elimina il servizio da Cloud Run.
- In Cloud Console, vai alla pagina Servizi per Cloud Run.
- Seleziona il servizio che vuoi eliminare.
- Fai clic su Elimina delete per eliminare il servizio.
Passaggi successivi
- Prova altri tutorial su Cloud Functions.
- Prova Cloud Run, che consente di eseguire container stateless in un ambiente completamente gestito o nel tuo cluster Google Kubernetes Engine.