Controllo dell'accesso con IAM

Questa pagina descrive le opzioni di controllo dell'accesso in Cloud Data Fusion.

Puoi controllare l'accesso alle risorse in Cloud Data Fusion nei seguenti modi:

  • Per controllare l'accesso per le operazioni del piano di controllo, come la creazione e l'aggiornamento delle istanze tramite la console Google Cloud, Google Cloud CLI e l'API REST, utilizza Identity and Access Management (IAM), come descritto in questa pagina.

  • Per concedere l'accesso ai Google Cloud servizi dati, come BigQuery o Cloud Storage, a un account di servizio in cui sono in esecuzione le pipeline, utilizza IAM.

  • Per controllare le autorizzazioni granulari per le azioni eseguite nell'istanza, note come operazioni di piano dati, come l'avvio delle pipeline, utilizza il controllo degli accessi basato sui ruoli (RBAC).

Per informazioni sull'architettura e sulle risorse coinvolte nel controllo dell'accesso di Cloud Data Fusion, consulta Networking. Per informazioni sulla concessione di ruoli e autorizzazioni, consulta Gestire l'accesso a progetti, cartelle e organizzazioni.

Informazioni su IAM in Cloud Data Fusion

Puoi controllare l'accesso alle funzionalità di Cloud Data Fusion concedendo ruoli e autorizzazioni IAM agli account di servizio e ad altri principali nel tuo progetto Google Cloud.

Per concedere agli account utente l'accesso granulare in modo che possano utilizzare l'interfaccia web di Cloud Data Fusion, utilizza il RBAC.

Per impostazione predefinita, Cloud Data Fusion utilizza i seguenti account di servizio:

Account di servizio Cloud Data Fusion

L'account di servizio Cloud Data Fusion è un agente di servizio gestito da Google che può accedere alle risorse del cliente al momento della progettazione della pipeline. Questo agente di servizio viene aggiunto automaticamente a un progetto quando attivi l'API Cloud Data Fusion. Viene utilizzato per tutte le istanze del progetto.

L'agente di servizio ha le seguenti responsabilità:

  • Comunicazione con altri servizi, come Cloud Storage, BigQuery o Datastream durante la progettazione della pipeline.

  • Attivare l'esecuzione eseguendo il provisioning dei cluster Dataproc e inviando i job di pipeline.

Ruoli per l'account di servizio Cloud Data Fusion

Per impostazione predefinita, l'account di servizio Cloud Data Fusion ha solo il ruolo Agente di servizio API Cloud Data Fusion (roles/datafusion.serviceAgent).

Il nome principale di questo agente di servizio è service-CUSTOMER_PROJECT_NUMBER@gcp-sa-datafusion.iam.gserviceaccount.com.

Le seguenti risorse predefinite sono associate al ruolo Agente di servizio dell'API Cloud Data Fusion.

Ruolo Risorsa Autorizzazioni
Cloud Data Fusion API Service Agent Servizi associati:
  • BigQuery
  • Bigtable
  • Compute Engine
  • Dataproc
  • Cloud DNS
  • Firebase
  • Cloud Monitoring
  • Connettività di rete
  • Integrazione della sicurezza di rete
  • API Network Services
  • Policy organizzazione
  • API Recommender
  • API Cloud Resource Manager
  • Networking di servizi
  • Utilizzo dei servizi
  • Spanner
  • Cloud Storage
  • Cloud Service Mesh
Consulta le autorizzazioni dell'agente di servizio API Cloud Data Fusion.

Account di servizio predefinito o personalizzato Compute Engine

L'account di servizio Compute Engine è l'account predefinito utilizzato da Cloud Data Fusion per eseguire il deployment ed eseguire job che accedono ad altre risorseGoogle Cloud . Per impostazione predefinita, si connette a una VM del cluster Dataproc per consentire a Cloud Data Fusion di accedere alle risorse Dataproc durante l'esecuzione di una pipeline.

Puoi scegliere un account di servizio personalizzato da collegare al cluster Dataproc quando crei un'istanza Cloud Data Fusion o creando nuovi profili di calcolo nell'interfaccia web di Cloud Data Fusion.

Per saperne di più, consulta Account di servizio in Cloud Data Fusion.

Ruoli per l'account di servizio Compute Engine

Per impostazione predefinita, per accedere alle risorse (ad esempio origini e destinazioni) quando esegui una pipeline, Cloud Data Fusion utilizza l'account di servizio predefinito di Compute Engine.

Puoi configurare un account di servizio personalizzato gestito dall'utente per le istanze Cloud Data Fusion e concedere un ruolo a questo account. Successivamente, puoi scegliere questo account di servizio quando crei nuove istanze.

Ruolo di Cloud Data Fusion Runner

Nel progetto contenente l'istanza Cloud Data Fusion, concedi il ruolo Runner Cloud Data Fusion (datafusion.runner) sia agli account di servizio personalizzati gestiti dall'utente sia a quelli predefiniti.

Ruolo Descrizione Autorizzazione
Data Fusion Runner (datafusion.runner) Consente all'account di servizio Compute Engine di comunicare con i servizi Cloud Data Fusion nel progetto tenant datafusion.instances.runtime

Ruolo Utente account di servizio

Nell'account di servizio predefinito o gestito dall'utente nel progetto in cui vengono avviati i cluster Dataproc quando esegui le pipeline, concedi all'account di servizio Cloud Data Fusion il ruolo Utente account di servizio (roles/iam.serviceAccountUser).

Per ulteriori informazioni, vedi Concedere l'autorizzazione all'account di servizio.

Ruolo Dataproc Worker

Per eseguire i job sui cluster Dataproc, concedi il ruolo Dataproc Worker (roles/dataproc.worker) agli account di servizio predefiniti o gestiti dall'utente utilizzati dalle pipeline Cloud Data Fusion.

Ruoli per gli utenti

Per attivare qualsiasi operazione in Cloud Data Fusion, devi avere autorizzazioni sufficienti. Le singole autorizzazioni vengono raggruppate in ruoli e tu concessi i ruoli all'entità.

Se il RBAC non è abilitato o se utilizzi una versione di Cloud Data Fusion che non supporta il RBAC, gli utenti con qualsiasi ruolo IAM di Cloud Data Fusion hanno accesso completo all'interfaccia web di Cloud Data Fusion. Il ruolo Amministratore consente agli utenti di gestire solo l'istanza, ad esempio le operazioni Create, Update, Upgrade e Delete.

Concedi i seguenti ruoli alle entità, a seconda delle autorizzazioni di cui hanno bisogno in Cloud Data Fusion.

Ruolo Descrizione Autorizzazioni
Cloud Data Fusion Admin (roles/datafusion.admin) Tutte le autorizzazioni di visualizzazione, oltre alle autorizzazioni per creare, aggiornare ed eliminare le istanze Cloud Data Fusion.
  • datafusion.instances.get
  • datafusion.instances.list
  • datafusion.instances.create
  • datafusion.instances.delete
  • datafusion.instances.update
  • datafusion.operations.get
  • datafusion.operations.list
  • datafusion.operations.cancel
  • resourcemanager.projects.get
  • resourcemanager.projects.list
Visualizzatore Cloud Data Fusion (roles/datafusion.viewer)
  • Può visualizzare le istanze Cloud Data Fusion del progetto nella console Google Cloud.
  • Impossibile creare, aggiornare o eliminare le istanze Cloud Data Fusion.
  • datafusion.instances.get
  • datafusion.instances.list
  • datafusion.operations.get
  • datafusion.operations.list
  • resourcemanager.projects.get
  • resourcemanager.projects.list

Accedere alle risorse di un altro progetto in fase di progettazione

Questa sezione descrive il controllo dell'accesso alle risorse che si trovano in un progetto Google Cloud diverso dall'istanza Cloud Data Fusion al momento della progettazione.

Quando progetti le pipeline nell'interfaccia web di Cloud Data Fusion, potresti utilizzare funzioni come Wrangler o Anteprima che accedono alle risorse in altri progetti.

Le sezioni seguenti descrivono come determinare l'account di servizio nel tuo ambiente e concedere le autorizzazioni appropriate.

Determina l'account di servizio del tuo ambiente

Il nome dell'account di servizio è Account di servizio Cloud Data Fusion e il principale per questo agente di servizio è service-CUSTOMER_PROJECT_NUMBER@gcp-sa-datafusion.iam.gserviceaccount.com.

Concedi l'autorizzazione ad accedere alle risorse di un altro progetto

Per concedere i ruoli che concedono l'autorizzazione ad accedere a varie risorse, segui questi passaggi:

  1. Nel progetto in cui esiste la risorsa di destinazione, aggiungi l'account di servizio Cloud Data Fusion (service-CUSTOMER_PROJECT_NUMBER@gcp-sa-datafusion.iam.gserviceaccount.com) come entità.
  2. Concedi i ruoli all'account di servizio Cloud Data Fusion sulla risorsa di destinazione nel progetto in cui esiste la risorsa di destinazione.

Dopo aver concesso i ruoli, puoi accedere alle risorse di un progetto diverso in fase di progettazione nello stesso modo in cui accedi alle risorse del progetto in cui si trova la tua istanza.

Accedere alle risorse di un altro progetto in fase di esecuzione

Questa sezione descrive il controllo dell'accesso alle risorse che si trovano in un progetto Google Cloud diverso dall'istanza Cloud Data Fusion al momento dell'esecuzione.

Al momento dell'esecuzione, la pipeline viene eseguita su un cluster Dataproc, che può accedere alle risorse di altri progetti. Per impostazione predefinita, il cluster Dataproc viene avviato nello stesso progetto dell'istanza Cloud Data Fusion, ma puoi utilizzare i cluster in un altro progetto.

Per accedere alle risorse di altri Google Cloud progetti, segui questi passaggi:

  1. Determina l'account di servizio per il progetto.
  2. Nel progetto in cui si trova la risorsa, concedi i ruoli IAM all'account di servizio predefinito di Compute Engine per concedergli l'accesso alle risorse di un altro progetto.

Determina l'account di servizio Compute Engine

Per ulteriori informazioni sull'account di servizio Compute Engine, consulta Informazioni su IAM in Cloud Data Fusion.

Concedi l'accesso alle risorse IAM in un altro progetto

L'account di servizio predefinito di Compute Engine richiede autorizzazioni per accedere alle risorse di un altro progetto. Questi ruoli e autorizzazioni possono essere diversi a seconda della risorsa a cui vuoi accedere.

Per accedere alle risorse:

  1. Concedi ruoli e autorizzazioni, specificando il tuo account di servizio Compute Engine come entità nel progetto in cui esiste la risorsa di destinazione.
  2. Aggiungi i ruoli appropriati per accedere alla risorsa.

Autorizzazioni API Cloud Data Fusion

Per eseguire l'API Cloud Data Fusion sono necessarie le seguenti autorizzazioni.

Chiamata API Autorizzazione
instances.create datafusion.instances.create
instances.delete datafusion.instances.delete
instances.list datafusion.instances.list
instances.get datafusion.instances.get
instances.update datafusion.instances.update
operations.cancel datafusion.operations.cancel
operations.list datafusion.operations.list
operations.get datafusion.operations.get

Autorizzazioni per le attività comuni

Le attività comuni in Cloud Data Fusion richiedono le seguenti autorizzazioni:

Attività Autorizzazioni
Accedere all'interfaccia web di Cloud Data Fusion datafusion.instances.get
Accedere alla pagina Istanze di Cloud Data Fusion nella console Google Cloud datafusion.instances.list
Accedere alla pagina Dettagli di un'istanza datafusion.instances.get
Creazione di una nuova istanza datafusion.instances.create
Aggiornamento delle etichette e delle opzioni avanzate per personalizzare un'istanza datafusion.instances.update
Eliminazione di un'istanza datafusion.instances.delete

Passaggi successivi