Molte app devono eseguire l'elaborazione in background al di fuori del contesto di una richiesta web. Questo tutorial crea un'app web che consente agli utenti di inserire il testo da tradurre e poi mostra un elenco delle traduzioni precedenti. La traduzione viene eseguita in background per evitare di bloccare la richiesta dell'utente.
Il seguente diagramma illustra il processo di richiesta di traduzione.
Ecco la sequenza di eventi relativi al funzionamento dell'app Tutorial:
- Visita la pagina web per visualizzare un elenco delle traduzioni precedenti, memorizzate in Firestore.
- Richiedi una traduzione del testo inserendo un modulo HTML.
- La richiesta di traduzione viene pubblicata in Pub/Sub.
- Un'app Cloud Run riceve il messaggio Pub/Sub.
- L'app Cloud Run utilizza Cloud Translation per tradurre il testo.
- L'app Cloud Run archivia il risultato in Firestore.
Questo tutorial è rivolto a chiunque sia interessato a saperne di più sull'elaborazione in background con Google Cloud. Non è richiesta alcuna esperienza precedente con Pub/Sub, Firestore, App Engine o Cloud Run. Tuttavia, per comprendere tutto il codice, è utile avere una certa esperienza con PHP, JavaScript e HTML.
Obiettivi
- Comprendi ed esegui il deployment dei servizi Cloud Run.
- Comprendere ed eseguire il deployment di un'app App Engine.
- Prova l'app.
Costi
In questo documento utilizzi i seguenti componenti fatturabili di Google Cloud:
Per generare una stima dei costi basata sull'utilizzo previsto,
utilizza il Calcolatore prezzi.
Una volta completate le attività descritte in questo documento, puoi evitare la fatturazione continua eliminando le risorse che hai creato. Per ulteriori informazioni, consulta la pagina 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, Cloud Run, Pub/Sub, and Cloud Translation APIs.
-
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, Cloud Run, Pub/Sub, and Cloud Translation APIs.
-
Nella console Google Cloud, apri l'app in Cloud Shell.
Cloud Shell fornisce l'accesso tramite riga di comando alle risorse cloud direttamente dal browser. Apri Cloud Shell nel browser e fai clic su Continua per scaricare il codice campione e modificarlo nella directory dell'app.
-
In Cloud Shell, configura lo strumento
gcloud
in modo da utilizzare il tuo progetto Google Cloud:# Configure gcloud for your project gcloud config set project YOUR_PROJECT_ID
Informazioni sul backend Cloud Run
Puoi definire una singola funzione PHP translateString
e configurare il tuo servizio Cloud Run per rispondere a un messaggio Pub/Sub richiamando questa funzione.
La funzione deve importare diverse dipendenze per connettersi a Firestore e Translation.
Cloud Run inizia con l'inizializzazione dei client Firestore e Pub/Sub. Poi analizza i dati dei messaggi Pub/Sub per ottenere il testo da tradurre e la lingua di destinazione desiderata.
L'API Translation viene utilizzata per tradurre la stringa nella lingua desiderata.
La funzione assegna un nome univoco alla richiesta di traduzione, per assicurarci di non memorizzare traduzioni duplicate. Poi, traduce in una transazione Firestore per assicurarsi che le esecuzioni simultanee non eseguano accidentalmente la stessa traduzione due volte.
Creazione e deployment del backend Cloud Run
Crea l'app Cloud Run nella directory
backend
:gcloud builds submit backend/ \ --tag gcr.io/PROJECT_ID/background-function
Esegui il deployment dell'app Cloud Run utilizzando il tag immagine del passaggio precedente:
gcloud run deploy background-processing-function --platform managed \ --image gcr.io/PROJECT_ID/background-function --region REGION
Dove
REGION
corrisponde a una regione Google Cloud.Al termine del deployment, nell'output comando vedrai un URL per l'app di cui hai eseguito il deployment. Ad esempio:
Service [background-processing-function] revision [default-00002-vav] has been deployed and is serving 100 percent of traffic at https://default-c457u4v2ma-uc.a.run.app
Copia questo URL per il passaggio successivo.
Configurazione della sottoscrizione Pub/Sub
La tua app Cloud Run riceverà messaggi da Pub/Sub ogni volta che viene pubblicato un messaggio nell'argomento translate
.
Un controllo di autenticazione integrato garantisce che il messaggio Pub/Sub contenga un token di autorizzazione valido di un account di servizio che dispone dell'autorizzazione per richiamare il backend Cloud Run.
I passaggi successivi illustrano la configurazione dell'argomento Pub/Sub, della sottoscrizione e dell'account di servizio per effettuare chiamate autenticate al backend Cloud Run. Scopri di più su questa integrazione in Autenticazione tra servizi.
Crea l'argomento
translate
per la pubblicazione di nuove richieste di traduzione:gcloud pubsub topics create translate
Abilita il tuo progetto per creare token di autenticazione Pub/Sub:
gcloud projects add-iam-policy-binding PROJECT_ID \ --member=serviceAccount:service-PROJECT_NUMBER@gcp-sa-pubsub.iam.gserviceaccount.com \ --role=roles/iam.serviceAccountTokenCreator
Dove
PROJECT_NUMBER
è il numero di progetto Google Cloud, che puoi trovare eseguendogcloud projects describe PROJECT_ID | grep projectNumber
.Crea o seleziona un account di servizio per rappresentare l'identità della sottoscrizione Pub/Sub.
gcloud iam service-accounts create cloud-run-pubsub-invoker \ --display-name "Cloud Run Pub/Sub Invoker"
Nota: puoi utilizzare
cloud-run-pubsub-invoker
o sostituirlo con un nome univoco all'interno del tuo progetto Google Cloud.Concedi all'account di servizio dell'invoker l'autorizzazione per richiamare il tuo servizio
background-processing-function
:gcloud run services add-iam-policy-binding background-processing-function \ --member=serviceAccount:cloud-run-pubsub-invoker@PROJECT_ID.iam.gserviceaccount.com \ --role=roles/run.invoker --platform managed --region REGION
La propagazione delle modifiche a Identity and Access Management può richiedere diversi minuti. Nel frattempo, potresti visualizzare
HTTP 403
errori nei log del servizio.Crea una sottoscrizione Pub/Sub con l'account di servizio:
gcloud pubsub subscriptions create run-translate-string --topic translate \ --push-endpoint=CLOUD_RUN_URL \ --push-auth-service-account=cloud-run-pubsub-invoker@PROJECT_ID.iam.gserviceaccount.com
Dove
CLOUD_RUN_URL
è l'URL HTTPS che hai copiato dopo la creazione e il deployment del backend.Il flag
--push-account-service-account
attiva la funzionalità push di Pub/Sub per Autenticazione e autorizzazione.Il tuo dominio di servizio Cloud Run viene registrato automaticamente per essere utilizzato con le sottoscrizioni Pub/Sub.
Comprendere l'app
L'app web ha due componenti principali:
-
Un server HTTP PHP per gestire le richieste web. Il server ha i seguenti
due endpoint:
-
/
: elenca tutte le traduzioni esistenti e mostra un modulo che gli utenti possono inviare per richiedere nuove traduzioni. -
/request-translation
: gli invii del modulo vengono inviati a questo endpoint, che pubblica la richiesta in Pub/Sub affinché venga tradotta in modo asincrono.
-
- Modello HTML compilato con le traduzioni esistenti del server PHP.
Il server HTTP
Nella directory
app
,index.php
inizia configurando l'app Lumen e registrando i gestori HTTP:Il gestore dell'indice (
/
) recupera tutte le traduzioni esistenti da Firestore e visualizza un modello con l'elenco:Il gestore della traduzione della richiesta, registrato all'indirizzo
/request-translation
, analizza l'invio del modulo HTML, convalida la richiesta e pubblica un messaggio in Pub/Sub:
Il modello HTML
Il modello HTML rappresenta la base per la pagina HTML mostrata all'utente, che consente così che l'utente possa vedere le traduzioni precedenti e richiederne di nuove. Il modello viene compilato dal server HTTP con l'elenco delle traduzioni esistenti.
-
L'elemento
<head>
del modello HTML include metadati, fogli di stile e JavaScript per la pagina:La pagina recupera gli asset CSS e JavaScript di Material Design Lite (MDL). La MDL ti consente di aggiungere un aspetto Material Design ai tuoi siti web.
La pagina utilizza JQuery per attendere il completamento del caricamento del documento e imposta un gestore di invio del modulo. Ogni volta che viene inviato il modulo della richiesta di traduzione, la pagina esegue una convalida del modulo minima per verificare che il valore non sia vuoto, quindi invia una richiesta asincrona all'endpoint
/request-translation
.Infine, viene visualizzata una snackbar MDL che indica se la richiesta è riuscita o se si è verificato un errore.
- Il corpo HTML della pagina utilizza un layout MDL e diversi componenti MDL per visualizzare un elenco di traduzioni e un modulo per richiedere traduzioni aggiuntive:
Esecuzione dell'app in Cloud Shell
Prima di provare a eseguire il deployment dell'app web, installa le dipendenze ed eseguile in locale.
Innanzitutto, installa le dipendenze con Composer. L'estensione gRPC per PHP è obbligatoria ed è preinstallata in Cloud Shell.
composer install -d app
Quindi, esegui il server web PHP integrato per pubblicare l'app:
APP_DEBUG=true php -S localhost:8080 -t app
Il flag
APP_DEBUG=true
mostrerà tutte le eccezioni che si verificano.In Cloud Shell, fai clic su Anteprima web , e seleziona Anteprima sulla porta 8080. Si apre una nuova finestra con la tua app in esecuzione.
Deployment dellapp web
Puoi utilizzare l'ambiente standard di App Engine per creare ed eseguire il deployment di un'app che viene eseguita in modo affidabile anche se sottoposta a un carico elevato e con grandi quantità di dati.
Questo tutorial utilizza l'ambiente standard di App Engine per eseguire il deployment del frontend HTTP.
app.yaml
configura l'app App Engine:
-
Dalla stessa directory del file
app.yaml
, esegui il deployment della tua app nell'ambiente standard di App Engine:gcloud app deploy
Test dell'app
Dopo aver eseguito il deployment della Cloud Function e dell'app App Engine, prova a richiedere una traduzione.
-
Per visualizzare l'app nel browser,inserisci il seguente URL:
https://PROJECT_ID.REGION_ID.r.appspot.com
Sostituisci quanto segue:
PROJECT_ID
: l'ID del tuo progetto Google CloudREGION_ID
: un codice assegnato da App Engine alla tua app
C'è una pagina con un elenco vuoto di traduzioni e un modulo per richiedere nuove traduzioni.
-
Nel campo Testo da tradurre, inserisci il testo da tradurre, ad esempio
Hello, World
. - Seleziona una lingua dall'elenco a discesa in cui vuoi tradurre il testo.
- Fai clic su Invia.
- Per aggiornare la pagina, fai clic su Aggiorna refresh. È presente una nuova riga nell'elenco di traduzione. Se non vedi una traduzione, attendi qualche secondo e riprova. Se continui a non vedere una traduzione, consulta la sezione successiva sul debug dell'app.
Debug dell'app
Se non riesci a connetterti all'app App Engine o non vedi nuove traduzioni, verifica quanto segue:
- Verifica che i comandi di deployment di
gcloud
siano stati completati correttamente e non abbiano restituito alcun errore. Se si sono verificati errori (ad esempiomessage=Build failed
), correggili, prova a creare e a eseguire il deployment dell'app Cloud Run e di eseguire di nuovo il deployment dell'app App Engine. Nella console Google Cloud, vai alla pagina Esplora log.
- Nell'elenco a discesa Risorse selezionate di recente, fai clic su Applicazione GAE, quindi su Tutti gli ID modulo. Viene visualizzato un elenco di richieste effettuate quando hai visitato la tua app. Se non vedi un elenco di richieste, conferma di aver selezionato Tutti i moduli_id dall'elenco a discesa. Se vengono visualizzati messaggi di errore stampati nella console Google Cloud, verifica che il codice dell'app corrisponda al codice nella sezione relativa alla comprensione dell'app web.
- Nell'elenco a discesa Risorse selezionate di recente, fai clic su Revisione Cloud Run, quindi su Tutti i log. Dovresti visualizzare una richiesta POST inviata all'URL dell'app di cui hai eseguito il deployment. In caso contrario, verifica che l'app Cloud Run e App Engine utilizzino lo stesso argomento Pub/Sub e che esista una sottoscrizione Pub/Sub per eseguire il push al tuo endpoint Cloud Run.
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 Google Cloud
- 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 le risorse del tutorial
Elimina l'app App Engine creata in questo tutorial:
- In the Google Cloud console, go to the Versions page for App Engine.
- Select the checkbox for the non-default app version that you want to delete.
- Per eliminare la versione dell'app, fai clic su Elimina.
Elimina il servizio Cloud Run di cui hai eseguito il deployment in questo tutorial:
gcloud run services delete background-processing-function
Puoi anche eliminare i servizi Cloud Run dalla console Google Cloud.
Elimina le altre risorse Google Cloud create in questo tutorial:
- Elimina l'argomento Pub/Sub
translate
- Elimina la sottoscrizione Pub/Sub
run-translate-string
- Elimina l'immagine container denominata
gcr.io/PROJECT_ID/background-processing
da Container Registry. - Eliminare l'account di servizio del chiamante
cloud-run-pubsub-invoker@PROJECT_ID.iam.gserviceaccount.com
- Elimina l'argomento Pub/Sub