Questo tutorial è destinato a coloro che non hanno mai creato app nel cloud, ad esempio ingegneri e sviluppatori web che vogliono imparare i concetti chiave dello sviluppo di app nel contesto di Google Cloud.
Obiettivi
- Scopri gli strumenti di base di Google Cloud, come Google Cloud Console e
gcloud
. - Eseguire il deployment dell'app in Cloud Run.
- Rendere persistenti i dati con Firestore.
- Archiviare in Cloud Storage i file caricati.
- Monitorare l'app con la suite operativa di Google Cloud.
Costi
In questo documento utilizzi i seguenti componenti fatturabili di Google Cloud:
Le istruzioni riportate in questo documento sono progettate per mantenere l'utilizzo delle risorse entro i limiti del livello Sempre gratis 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.
-
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.
-
Per creare un database Firestore in modalità Native, segui questa procedura:
-
In Cloud Console, vai alla pagina Visualizzatore negozio.
Vai al visualizzatore Firestore - Nella schermata Seleziona una modalità Cloud Firestore, fai clic su Seleziona modalità nativa.
- Seleziona una località per il tuo database Firestore. La località impostata corrisponde alla località predefinita delle risorse di Google Cloud per il tuo progetto Cloud . Questa località viene utilizzata per i servizi Google Cloud all'interno del tuo progetto Cloud che richiedono la geolocalizzazione. Nello specifico, si tratta del tuo bucket predefinito di Cloud Storage e della tua app Cloud Run.
- Fai clic su Crea database.
-
In Cloud Console, vai alla pagina Visualizzatore negozio.
-
Enable the Cloud Run Admin, Cloud Storage, Cloud Logging, and Error Reporting APIs.
-
Clona il repository di esempio e apri l'applicazione di esempio in Cloud Shell:
Vai a Cloud ShellCloud Shell fornisce l'accesso tramite riga di comando alle tue risorse Google Cloud direttamente dal browser.
- Per scaricare il codice di esempio e modificarlo nella directory dell'applicazione, fai clic su Continua.
-
In Cloud Shell, configura lo strumento
gcloud
in modo da utilizzare il nuovo progetto Google Cloud:# Configure gcloud for your project gcloud config set project PROJECT_ID
Sostituisci PROJECT_ID con l'ID progetto di Google Cloud che hai creato utilizzando Cloud Console.
L'interfaccia a riga di comando di Google Cloud è il metodo principale per interagire con le risorse Google Cloud dalla riga di comando. In questo tutorial, utilizzerai lo strumento
gcloud
per eseguire il deployment dell'app e monitorarla.
Esecuzione dell'app
- Se utilizzi già Cloud Shell e lo hai configurato per utilizzare Java 11,
aggiorna le alternative Java di shell, le variabili di ambiente
JAVA_HOME
ePATH
specifiche di Java 8. -
Modifica nella directory
bookshelf/1-cloud-run
ed esegui l'app: SostituisciGOOGLE_CLOUD_PROJECT=PROJECT_ID mvn -Plocal clean jetty:run-exploded
PROJECT_ID
con l'ID del progetto Google Cloud che hai creato. - In Cloud Shell, fai clic su Anteprima web , e seleziona Anteprima sulla porta 8080. Compare una nuova finestra in cui viene eseguita l'app.
Esecuzione del deployment dell'app in Cloud Run
Google Cloud offre varie opzioni per eseguire il codice. In questo esempio, viene utilizzato Cloud Run per eseguire il deployment di un'app scalabile in Google Cloud. Cloud Run non richiede la gestione dei server e scala automaticamente per supportare i picchi di traffico.
- Crea l'immagine utilizzando Jib:
mvn package jib:build -Dimage=gcr.io/PROJECT_ID/bookshelf
Sostituisci
PROJECT_ID
con l'ID del progetto Google Cloud che hai creato. - Esegui il deployment dell'immagine:
Sostituiscigcloud run deploy bookshelf --image gcr.io/
PROJECT_ID
/bookshelf \ --platform managed --region us-central1 --allow-unauthenticatedPROJECT_ID
con l'ID del progetto Google Cloud che hai creato.
Una volta eseguito il deployment, restituisce un endpoint all'applicazione in esecuzione in Cloud Run, nel seguente formato:
https://bookshelf-abcdefghij-uc.a.run.app
Ora l'app è visualizzabile a questo link, che d'ora in poi verrà chiamato YOUR_CODE_RUN_URL. Nel browser web, inserisci l'URL per visualizzare l'app.
Rendere persistenti i dati con Firestore
Non puoi archiviare informazioni sulle istanze di Cloud Run poiché vengono perse al riavvio dell'istanza e non esistono quando vengono create nuove istanze. Puoi, invece, utilizzare un database in cui tutte le istanze eseguono operazioni di lettura e scrittura.
Google Cloud offre varie opzioni per archiviare i dati. In questo esempio viene utilizzato Firestore per archiviare i dati di ogni libro. Firestore è un database di documenti NoSQL serverless completamente gestito che consente di archiviare i dati e di eseguire query su di essi. Firestore si ridimensiona automaticamente per soddisfare le esigenze dell'app, con una scalabilità fino a zero quando non la utilizzi. Aggiungi il tuo primo libro.
- Dal tuo browser web, vai a YOUR_CODE_RUN_URL.
-
Per creare un libro per l'applicazione di cui hai eseguito il deployment, fai clic su Add book (Aggiungi libro).
- Nel campo Title (Titolo), inserisci
Moby Dick
. - Nel campo Author (Autore), inserisci
Herman Melville
. -
Fai clic su Salva. Adesso esiste una voce nell'applicazione Bookshelf.
- In Cloud Console, fai clic su Aggiorna refresh per aggiornare la pagina di Firestore. I dati vengono visualizzati in Firestore. Ogni libro dell'app Bookshelf è archiviato come documento Firestore con un ID unico e tutti questi documenti sono archiviati in una raccolta Firestore. Ai fini di questo tutorial, la raccolta è chiamata "books" (libri).
Firestore archivia i libri mediante la libreria client di Firestore. Ecco un esempio di come recuperare un documento Firestore:
Per ulteriori informazioni sull'utilizzo di Firestore, consulta Aggiungere dati a Firestore.
Archiviare i caricamenti dei file in Cloud Storage
Dopo aver aggiunto un libro, devi aggiungere la rispettiva immagine di copertina. Non puoi archiviare i file nelle istanze. Un database non è la scelta giusta per i file di immagine. Utilizza, invece, Cloud Storage.
Cloud Storage è il principale archivio di blob per Google Cloud. Puoi utilizzare Cloud Storage per archiviare gli asset dell'app che vuoi condividere in Google Cloud. Per utilizzare Cloud Storage, devi creare un bucket Cloud Storage, ovvero un container di base che ospiti i tuoi dati.
- In Cloud Console, vai alla pagina Browser Cloud Storage.
- Fai clic su Crea bucket.
- Nella finestra di dialogo Crea bucket, inserisci un nome per il bucket aggiungendo
l'ID del progetto Google Cloud alla stringa
_bucket
, in modo che il nome sia simile aYOUR_PROJECT_ID_bucket
. Questo nome è soggetto ai requisiti per i nomi dei bucket. Puoi lasciare invariati i valori predefiniti di tutti gli altri campi. - Fai clic su Crea.
- Una volta creato il bucket, gli oggetti devono essere resi accessibili pubblicamente per poter essere visualizzati dagli utenti. Per rendere gli oggetti accessibili pubblicamente, consulta la pagina Rendere pubblici i dati.
-
Fai clic su Edit book (Modifica libro) e seleziona un'immagine da caricare come copertina del libro. Ad esempio, puoi utilizzare questa immagine di dominio pubblico:
-
Fai clic su Save (Salva). Viene visualizzata la
home page, dove è presente una voce per la tua app Bookshelf.
L'applicazione Bookshelf invia i file caricati a Cloud Storage mediante la libreria client di Cloud Storage.
Esegui la pulizia
Per evitare che al tuo Account Google Cloud vengano addebitati costi relativi alle risorse utilizzate in questo tutorial, elimina il progetto che contiene le risorse oppure mantieni il progetto ed elimina le singole risorse.
Elimina il progetto
- L'intero contenuto del progetto viene eliminato. Se hai utilizzato un progetto esistente per le attività descritte in questo documento, quando lo elimini elimini anche tutto il lavoro svolto nel progetto.
-
Gli ID progetto personalizzati non sono più disponibili.
Quando hai creato questo progetto, potresti aver creato un ID progetto personalizzato che vuoi utilizzare in futuro. Per conservare gli URL che utilizzano l'ID progetto, ad esempio un URL
appspot.com
, elimina le risorse selezionate all'interno del progetto anziché eliminare l'intero 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.
Se intendi esplorare più architetture, tutorial o guide rapide, il riuso dei progetti può aiutarti a non superare i limiti di quota.