Questo tutorial è destinato a coloro che non hanno mai creato applicazioni nel cloud, ad esempio ingegneri e sviluppatori web che vogliono imparare i concetti chiave di Google Cloud come si applicano a Google Cloud.
Obiettivi
- Imparare a utilizzare gli strumenti di base Google Cloud , come la 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 utilizzando Google Cloud Observability.
Costi
In questo documento vengono utilizzati i seguenti componenti fatturabili di Google Cloud:
Le istruzioni riportate in questo documento sono pensate per mantenere l'utilizzo delle risorse entro
i limiti del Google Cloud's Sempre senza costi
livello.
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 l'addebito di ulteriori costi eliminando le risorse che hai creato. Per saperne di più, consulta Esegui la pulizia.
Prima di iniziare
- Accedi al tuo Google Cloud account. Se non conosci Google Cloud, crea un account per valutare le prestazioni dei nostri prodotti in scenari reali. I nuovi clienti ricevono anche 300 $di crediti senza costi per l'esecuzione, il test e il deployment dei workload.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify 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.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
-
Per creare un database Firestore in modalità Native, segui questa procedura:
-
Nella Google Cloud console, vai alla pagina Crea database Firestore.
- Dalla schermata Seleziona una modalità di Cloud Firestore, fai clic su Seleziona modalità Native.
- Seleziona una località per il tuo database Firestore. La località impostata corrisponde alla località Google Cloud delle Google Cloud risorse predefinita per il tuo progetto . Questa località viene utilizzata per i Google Cloud servizi all'interno del tuo Google Cloud progetto 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.
-
Nella Google Cloud console, vai alla pagina Crea database Firestore.
-
Abilita le API Artifact Registry, Amministratore di Cloud Run, Cloud Build, Cloud Storage, Cloud Logging ed Error Reporting.
Ruoli richiesti per abilitare le API
Per abilitare le API, devi disporre del ruolo IAM Amministratore utilizzo servizi (
roles/serviceusage.serviceUsageAdmin), che contiene l'autorizzazioneserviceusage.services.enable. Scopri come concedere i ruoli. -
Clona il repository di esempio e apri l'applicazione di esempio in Cloud Shell:
Vai a Cloud ShellCloud Shell fornisce l'accesso da riga di comando alle tue Google Cloud risorse direttamente dal browser.
- Per scaricare il codice campione e modificarlo nella directory dell'applicazione, fai clic su Continua.
-
In Cloud Shell, configura lo strumento
gcloudin modo da utilizzare il nuovo Google Cloud progetto:# Configure gcloud for your project gcloud config set project PROJECT_ID
Sostituisci PROJECT_ID con l' Google Cloud ID progetto che hai creato utilizzando la Google Cloud console.
Il Google Cloud CLI è il metodo principale per interagire con le tue Google Cloud risorse dalla riga di comando. In questo tutorial utilizzerai lo strumento
gcloudper eseguire il deployment dell'app e per monitorarla.
Esegui l'app
-
Crea l'app, che scarica automaticamente le dipendenze:
go build
-
Esegui l'applicazione:
Sostituisci PROJECT_ID con l' Google Cloud ID progetto che hai creato.GOOGLE_CLOUD_PROJECT=PROJECT_ID ./bookshelf
- 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 si ridimensiona automaticamente per supportare i picchi di traffico.
- Esegui il container con Cloud Run:
gcloud run deploy bookshelf --region us-central1 --allow-unauthenticated \ --set-env-vars="GOOGLE_CLOUD_PROJECT=
PROJECT_ID" --source .Ora l'app è visualizzabile all'URL visualizzato nell'output di
gcloud run:Service [bookshelf] revision [bookshelf-00001] has been deployed and is serving 100 percent of traffic. Service URL: https://bookshelf-swsmmh5s5a-uc.a.run.app
-
Copia l'URL nel browser web per visualizzare l'app.
Per ulteriori informazioni sul deployment in Cloud Run, consulta la documentazione di Cloud Run.
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.
-
Per creare un libro per l'applicazione di cui hai eseguito il deployment, fai clic su Aggiungi libro.
- Nel campo Title (Titolo), inserisci
Moby Dick. - Nel campo Author (Autore), inserisci
Herman Melville. -
Fai clic su Save (Save). Adesso esiste una voce nell'applicazione Bookshelf.
-
Nella Google 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 univoco 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:
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.
- Nella Google Cloud console, vai alla pagina Browser in Cloud Storage.
- Fai clic su Crea bucket.
- Nella finestra di dialogo Crea bucket , inserisci un nome per il bucket aggiungendo l' Google Cloud ID del progetto alla stringa
_bucket, in modo che il nome sia simileYOUR_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'app Bookshelf invia i file caricati a Cloud Storage mediante la libreria client di Cloud Storage.
Per ulteriori informazioni sull'utilizzo di Cloud Storage, consulta la pagina Introduzione a Cloud Storage.
Monitorare l'app utilizzando Google Cloud Observability
Hai eseguito il deployment dell'app e hai creato e modificato i libri. Per monitorare questi eventi per i tuoi utenti, utilizza gestione delle prestazioni delle applicazioni (APM).
Monitorare i log con Cloud Logging
-
In the Google Cloud, vai a Esplora log
Vai a Esplora logPuoi monitorare l'app in tempo reale. In caso di problemi con l'applicazione, questa è una delle prime sezioni da controllare.
- Nell'elenco a discesa Risorsa, seleziona Revisione Cloud Run, Bookshelf.
Monitorare gli errori con Error Reporting
-
Nella Google Cloud console, vai alla pagina Error Reporting.
Vai alla pagina Error Reporting
Error Reporting evidenzia errori ed eccezioni nell'app e consente di configurare avvisi al riguardo. -
Nel browser, vai all'URL
/errorsnell'app.
YOUR_CLOUD_RUN_URL/errors
Viene generata una nuova eccezione di test che viene inviata a Google Cloud Observability.
-
Nella Google Cloud console, torna alla pagina Error Reporting . Dopo qualche secondo, viene visualizzato il nuovo errore. Fai clic su Ricarica automaticamente per evitare di aggiornare manualmente la pagina.
Libera spazio
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
- Nella Google Cloud console, vai alla pagina Gestisci risorse.
- Nell'elenco dei progetti, seleziona il progetto che vuoi eliminare, quindi fai clic su Elimina.
- Nella finestra di dialogo, digita l'ID progetto e fai clic su Chiudi per eliminare il progetto.