Tutorial sulle funzioni remote e sull'API Translation
Questo tutorial descrive come creare una funzione remota BigQuery, richiamare l'API Cloud Translation ed eseguire la traduzione dei contenuti da qualsiasi lingua allo spagnolo utilizzando SQL e Python.
I casi d'uso di questa funzione includono:
- Tradurre i commenti degli utenti su un sito web in una lingua locale
- Tradurre le richieste di assistenza da molte lingue in una lingua comune per gli addetti all'assistenza
Obiettivi
- Assegna i ruoli necessari al tuo account.
- Crea una funzione Cloud Run Functions.
- Creare un set di dati BigQuery.
- Crea una connessione BigQuery e account di servizio.
- Concedi le autorizzazioni al account di servizio BigQuery.
- Crea una funzione remota BigQuery.
- Chiama la funzione remota BigQuery.
Costi
In questo documento vengono utilizzati i seguenti componenti fatturabili di Cloud de Confiance by S3NS:
Prima di iniziare
Ti consigliamo di creare un progetto Cloud de Confiance per questo tutorial. Inoltre, assicurati di disporre dei ruoli necessari per completare questo tutorial.
Configurare un progetto Cloud de Confiance
Per configurare un progetto Cloud de Confiance per questo tutorial, completa questi passaggi:
-
In the Cloud de Confiance console, on the project selector page, select or create a Cloud de Confiance 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 Cloud de Confiance project.
Enable the BigQuery, BigQuery Connection, Cloud Translation, Cloud Run functions, Cloud Build, Cloud Logging, Cloud Pub/Sub, Artifact Registry, and Cloud Run Admin APIs.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.
Ruoli richiesti per il tuo account
Per ottenere le autorizzazioni necessarie per eseguire le attività descritte in questo tutorial, chiedi all'amministratore di concederti i seguenti ruoli IAM nel tuo progetto:
- Proprietario dati BigQuery (
roles/bigquery.dataOwner) - Amministratore connessioni BigQuery (
roles/bigquery.connectionAdmin) - Cloud Functions Developer (
roles/cloudfunctions.developer)
Per saperne di più sulla concessione dei ruoli, consulta Gestisci l'accesso a progetti, cartelle e organizzazioni.
Questi ruoli predefiniti contengono le autorizzazioni necessarie per eseguire le attività descritte in questo tutorial. Per vedere quali sono esattamente le autorizzazioni richieste, espandi la sezione Autorizzazioni obbligatorie:
Autorizzazioni obbligatorie
Per eseguire le attività di questo tutorial sono necessarie le seguenti autorizzazioni:
-
bigquery.datasets.create -
bigquery.connections.create -
bigquery.connections.get -
cloudfunctions.functions.create
Potresti anche ottenere queste autorizzazioni con ruoli personalizzati o altri ruoli predefiniti.
Ruoli richiesti per il account di servizio Compute Engine predefinito
Quando hai attivato l'API per Cloud Run Functions, è stato creato un service account predefinito di Compute Engine. Per completare questo tutorial, devi concedere a questo account di serviziot predefinito il ruolo di utente API Cloud Translation.
Copia l'account di servizio predefinito di Compute Engine. Il account di servizio predefinito ha il seguente aspetto:
PROJECT_NUMBER-compute@developer.s3ns-system.iam.gserviceaccount.comSostituisci
PROJECT_NUMBERcon l'ID progetto.Nella console Cloud de Confiance vai alla pagina IAM.
Seleziona il progetto.
Fai clic su Concedi accesso, poi nel campo Nuove entità incolla il account di servizio predefinito di Compute Engine che hai copiato in precedenza.
Nell'elenco Assegna ruoli, cerca e seleziona Utente API Cloud Translation.
Fai clic su Salva.
Crea una funzione Cloud Run Functions
Utilizzando Cloud Run Functions, crea una funzione che traduce il testo di input in spagnolo.
Crea una funzione Cloud Run Functions con le seguenti specifiche:
- Per Ambiente, seleziona 2ª gen..
- In Nome funzione, inserisci
translation-handler. - In Regione, seleziona us-central1.
In Numero massimo di istanze, inserisci
10.Questa impostazione si trova nella sezione Impostazioni di runtime, build, connessioni e sicurezza.
In questo tutorial, utilizziamo un valore inferiore a quello predefinito per controllare il tasso di richieste inviate a Translation.
Per Runtime, seleziona Python 3.10.
In Entry point, inserisci
handle_translation.
Nell'elenco dei file, seleziona main.py, quindi incolla il seguente codice.
Prima di provare questo esempio, segui le istruzioni di configurazione di Python nella guida rapida di BigQuery per l'utilizzo delle librerie client. Per saperne di più, consulta la documentazione di riferimento dell'API BigQuery Python.
Per eseguire l'autenticazione in BigQuery, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
Prima di eseguire gli esempi di codice, imposta la variabile di ambiente
GOOGLE_CLOUD_UNIVERSE_DOMAINsus3nsapis.fr.Aggiorna
<your location>conus-central1.Nell'elenco dei file, seleziona requirements.txt e poi incolla il seguente testo:
Fai clic su Esegui il deployment e attendi che venga eseguito il deployment della funzione.
Fai clic sulla scheda Trigger.
Copia il valore dell'URL trigger e salvalo per un secondo momento. Devi utilizzare questo URL quando crei una funzione remota di BigQuery.
Crea un set di dati BigQuery
Crea un set di dati BigQuery che conterrà la funzione remota. Quando crei il set di dati, includi queste specifiche:
- In ID set di dati, inserisci
remote_function_test. - Per Tipo di località, seleziona Multi-regione.
- Per Multi-regione, seleziona Stati Uniti (più regioni negli Stati Uniti).
Crea una connessione BigQuery e account di servizio
Crea una connessione BigQuery per poter implementare una funzione remota con qualsiasi lingua supportata in Cloud Run Functions e Cloud Run. Quando crei una connessione, viene creato un account di servizio per quella connessione.
Crea una connessione alla risorsa Cloud de Confiance con le seguenti specifiche:
- Per Tipo di connessione, seleziona BigLake e funzioni remote (risorsa Cloud).
- In ID connessione, inserisci
remote-function-connection. - Per Tipo di località, seleziona Multi-regione.
- Per Multi-regione, seleziona Stati Uniti (più regioni negli Stati Uniti).
Apri l'elenco Connessioni e seleziona
us.remote-function-connection.Copia l'ID account di servizio e salvalo per dopo. Nel passaggio successivo devi concedere le autorizzazioni a questo ID.
Concedi le autorizzazioni al account di servizio BigQuery
Il account di servizio che hai creato nel passaggio precedente deve disporre dell'autorizzazione per utilizzare Cloud Run, in modo che la funzione remota BigQuery possa utilizzare la funzione Cloud Run Functions. Per concedere le autorizzazioni al account di servizio, completa i seguenti passaggi:
Vai alla pagina Cloud Run.
Seleziona il progetto.
Seleziona la casella di controllo accanto a
translation-handler.Nel riquadro Autorizzazioni, fai clic su Aggiungi entità.
Nel campo Nuove entità, inserisci l'ID account di servizio che hai copiato in precedenza.
Nell'elenco Assegna ruoli, cerca e seleziona Cloud Run Invoker.
Fai clic su Salva.
Crea una funzione remota BigQuery
Per utilizzare la funzione Cloud Run Functions che traduce il testo in spagnolo con una funzione remota BigQuery, completa i seguenti passaggi.
Nella console Cloud de Confiance , vai alla pagina BigQuery.
Nell'editor di query, inserisci la seguente query:
CREATE OR REPLACE FUNCTION `remote_function_test.translate_text`(x STRING) RETURNS STRING REMOTE WITH CONNECTION `us.remote-function-connection` OPTIONS ( endpoint = 'TRIGGER_URL', max_batching_rows = 10);Sostituisci
TRIGGER_URLcon l'URL del trigger che hai salvato in precedenza quando hai creato una funzione Cloud Run Functions.Fai clic su Esegui. Viene visualizzato un messaggio simile al seguente:
This statement created a new function named your_project.remote_function_test.translate_text.
Chiama la funzione remota BigQuery
Dopo aver creato la funzione Cloud Run, testala per assicurarti che sia collegata alla funzione Cloud Run Functions e produca i risultati previsti in spagnolo.
Nell'editor di query di BigQuery, inserisci la query seguente e poi fai clic su Esegui.
SELECT remote_function_test.translate_text('This new feature is fantastic!') AS translated_text;I risultati sono simili ai seguenti:
+-------------------------------------------+ | translated_text | +-------------------------------------------+ | ¡Esta nueva característica es fantástica! | +-------------------------------------------+
(Facoltativo) Per testare la funzione remota su un set di dati pubblico, inserisci la seguente query e poi fai clic su Esegui. Per limitare i risultati restituiti, utilizza la clausola
LIMIT.SELECT text, remote_function_test.translate_text(text) AS translated_text FROM (SELECT text FROM `bigquery-public-data.hacker_news.full` LIMIT 3);I risultati sono simili ai seguenti:
+---------------------------------------------------------------------------+ | text | translated_text | +---------------------------------------------------------------------------+ | These benchmarks look good. | Estos puntos de referencia se ven bien. | | Who is using Java? | ¿Quién está usando Java? | | You need more database storage. | Necesitas más almacenamiento. | +---------------------------------------------------------------------------+
Elimina le risorse
Se non prevedi di utilizzare queste funzioni in questo progetto, puoi evitare costi aggiuntivi eliminando il progetto. In questo modo, tutte le risorse associate al progetto vengono eliminate definitivamente.
- Nella console Cloud de Confiance , vai alla pagina Gestisci risorse.
- Nell'elenco dei progetti, seleziona quello che vuoi eliminare, quindi fai clic su Elimina.
- Nella finestra di dialogo, digita l'ID progetto, quindi fai clic su Chiudi per eliminare il progetto.
Passaggi successivi
- Scopri come utilizzare le funzioni remote in BigQuery.
- Scopri di più sulla traduzione.
- Scopri di più su Cloud Run Functions.
- Scopri di più su Cloud Run.