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 testo per la traduzione e quindi mostra un elenco di traduzioni precedenti. La traduzione viene eseguita in background per evitare di bloccare la richiesta dell'utente.
Il seguente diagramma illustra la procedura di richiesta di traduzione.
Ecco la sequenza degli eventi per il funzionamento dell'app:
- Visita la pagina web per visualizzare un elenco delle traduzioni precedenti, archiviate in Firestore.
- Richiedi una traduzione del testo inserendo un modulo HTML.
- La richiesta di traduzione è pubblicata in Pub/Sub.
- Viene attivata una funzione Cloud Functions collegata a quell'argomento Pub/Sub.
- La funzione Cloud Functions utilizza Cloud Translation per tradurre il testo.
- La funzione Cloud Functions archivia il risultato in Firestore.
Questo tutorial è destinato a chiunque sia interessato a conoscere l'elaborazione in background con Google Cloud. Non è richiesta alcuna esperienza precedente con Pub/Sub, Firestore, App Engine o Cloud Functions. Tuttavia, per comprendere tutto il codice, è utile avere un po' di esperienza con Node.js, JavaScript e HTML.
Obiettivi
- Capire ed eseguire il deployment di una funzione Cloud Functions.
- Capire 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 Functions, 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 Functions, 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 tue risorse cloud direttamente dal browser. Apri Cloud Shell nel browser e fai clic su Continua per scaricare il codice di esempio e passare alla 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 sulla funzione Cloud Functions
La funzione inizia importando diverse dipendenze come Firestore e Translation. I client Firestore e Translation globali sono inizializzati, in modo da poter essere riutilizzati tra le chiamate delle funzioni. In questo modo, non dovrai inizializzare nuovi client per ogni chiamata a una funzione, il che rallenterebbe l'esecuzione.
L'API Translation traduce la stringa nella lingua selezionata.
La funzione Cloud Functions analizza il messaggio Pub/Sub per ottenere il testo da tradurre e la lingua di destinazione desiderata.
L'app richiede una traduzione e memorizza il risultato in Firestore.
Deployment della funzione Cloud Functions
Nella stessa directory del file
translate.js
, esegui il deployment della funzione Cloud Functions con un trigger Pub/Sub:gcloud functions deploy translate --runtime nodejs10 --trigger-topic translate
Comprendere l'app
I componenti principali dell'app web sono due:
-
Un server HTTP Node.js 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 di moduli vengono inviati a questo endpoint, il che pubblica la richiesta a Pub/Sub da tradurre in modo asincrono.
-
- Un modello HTML compilato con le traduzioni esistenti del server Node.js.
Il server HTTP
Nella directory
server
,app.js
inizia configurando l'app e registrando i gestori HTTP:Il gestore di indici (
/
) riceve tutte le traduzioni esistenti da Firestore e compila un modello HTML con l'elenco:Le nuove traduzioni vengono richieste inviando un modulo HTML. Il gestore di traduzione delle richieste, registrato presso
/request-translation
, analizza l'invio del modulo, convalida la richiesta e pubblica un messaggio in Pub/Sub:
Il modello HTML
Il modello HTML è la base della pagina HTML mostrata all'utente in modo che possa visualizzare 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:Nella pagina sono presenti gli asset CSS e JavaScript Material Design Lite (MDL). MDL ti consente di aggiungere un'aspetto di Material Design ai tuoi siti web.
La pagina utilizza JQuery per attendere che il documento termini il caricamento e impostare un gestore per l'invio del modulo. Ogni volta che viene inviato il modulo di richiesta di traduzione, la pagina esegue una convalida minima del modulo per verificare che il valore non sia vuoto, quindi invia una richiesta asincrona all'endpoint
/request-translation
.Infine, viene visualizzato uno snackbar MDL per indicare se la richiesta è andata a buon fine o se ha riscontrato 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:
Eseguire il deployment dell'app web
Puoi utilizzare l'ambiente standard di App Engine per creare ed eseguire il deployment di un'app che viene eseguita in modo affidabile con un carico elevato e con grandi quantità di dati.
Questo tutorial utilizza l'ambiente standard di App Engine per il deployment del frontend HTTP.
app.yaml
configura l'app App Engine:
-
Dalla stessa directory del file
app.yaml
, esegui il deployment della tua applicazione nell'ambiente standard di App Engine:gcloud app deploy
Test dell'app
Dopo aver eseguito il deployment della funzione Cloud Functions 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
Una pagina con l'elenco delle traduzioni vuoto e un modulo per richiedere nuove traduzioni.
-
Nel campo Testo da tradurre, inserisci del testo da tradurre, ad esempio
Hello, World
. - Seleziona dall'elenco a discesa una lingua in cui vuoi tradurre il testo.
- Fai clic su Invia.
- Per aggiornare la pagina, fai clic su Aggiorna refresh. Nell'elenco di traduzioni è presente una nuova riga. Se non vedi una traduzione, attendi qualche secondo e riprova. Se non vedi ancora la traduzione, consulta la prossima sezione sul debug dell'app.
Eseguire il debug dell'app
Se non riesci a connetterti all'app App Engine o non vedi nuove traduzioni, controlla quanto segue:
-
Verifica che i comandi di deployment di
gcloud
siano stati completati correttamente e non abbiano restituito errori. Se si sono verificati errori, correggili e riprova a eseguire il deployment della funzione Cloud Functions e dell'app App Engine. -
Nella console Google Cloud, vai alla pagina Visualizzatore log.
Vai alla pagina Visualizzatore log- Nell'elenco a discesa Risorse selezionate di recente, fai clic su Applicazione GAE, quindi fai clic su All_module_All. Viene visualizzato un elenco di richieste da quando hai visitato la tua app. Se non viene visualizzato un elenco di richieste, conferma di aver selezionato All module_id dall'elenco a discesa. Se vengono visualizzati messaggi di errore nella console Google Cloud, verifica che il codice dell'app corrisponda al codice nella sezione Informazioni sull'app.
-
Nell'elenco a discesa Risorse selezionate di recente, fai clic su Funzione Cloud Functions e quindi su Nome di tutte le funzioni. Viene visualizzata una funzione per ogni traduzione richiesta. In caso contrario, verifica che
la funzione Cloud Functions e l'app App Engine utilizzino lo stesso
argomento Pub/Sub:
- Nel file
background/server/app.js
, controlla che la costanteTOPIC_NAME
sia"translate"
. - Quando esegui il deployment della funzione Cloud Functions, assicurati di includere il flag
--trigger-topic=translate
.
- Nel file
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 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 l'istanza di App Engine
- 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 la funzione Cloud Functions
-
Elimina la funzione Cloud Functions creata in questo tutorial:
gcloud functions delete Translate
Passaggi successivi
- Prova altri tutorial di Cloud Functions.
- Scopri di più su App Engine.
- Prova Cloud Run, che ti consente di eseguire container stateless in un ambiente completamente gestito o nel tuo cluster Google Kubernetes Engine.