Cloud Storage supporta il flusso di dati in un bucket senza richiedere il salvataggio dei dati in un file. Questo è utile quando vuoi caricare dati ma non conosci le dimensioni finali all'inizio del caricamento, ad esempio quando generi i dati di caricamento da un processo o quando comprimi un oggetto in tempo reale.
Utilizzo della convalida del checksum durante il flusso di dati
Poiché un checksum può essere fornito solo nella richiesta iniziale di un caricamento, spesso non è possibile utilizzare la convalida del checksum di Cloud Storage durante il flusso di dati. Ti consigliamo di utilizzare sempre la convalida del checksum, che puoi eseguire manualmente al termine del caricamento di un flusso di dati. Tuttavia, la convalida al termine del trasferimento fa sì che i dati danneggiati siano accessibili durante il tempo necessario per confermare il danneggiamento e la rimozione dei dati.
Se hai bisogno di una convalida del checksum prima del completamento del caricamento e che i dati diventino accessibili, non devi utilizzare un caricamento in modalità flusso. Devi utilizzare un'opzione di caricamento diversa che esegua la convalida del checksum prima di finalizzare l'oggetto.
Ruoli obbligatori
Per ottenere le autorizzazioni necessarie per trasmettere in streaming i caricamenti, chiedi all'amministratore di concederti uno dei seguenti ruoli:
Per i caricamenti che includono un blocco per la conservazione degli oggetti, chiedi all'amministratore di concederti il ruolo IAM Amministratore oggetti Storage (
roles/storage.objectAdmin
) per il bucket.Per tutti gli altri casi, chiedi all'amministratore di concederti il ruolo IAM Utente oggetti Storage (
roles/storage.objectUser
) per il bucket.
Questi ruoli predefiniti contengono le autorizzazioni necessarie per trasmettere i caricamenti in Cloud Storage. Per visualizzare le autorizzazioni esatte necessarie, espandi la sezione Autorizzazioni richieste:
Autorizzazioni obbligatorie
storage.objects.create
storage.objects.delete
- Questa autorizzazione è necessaria solo per i caricamenti che sovrascrivono un oggetto esistente.
storage.objects.get
storage.objects.list
- Questa autorizzazione è necessaria solo per utilizzare Google Cloud CLI per eseguire le istruzioni in questa pagina.
storage.objects.setRetention
- Questa autorizzazione è richiesta solo per i caricamenti che includono un blocco per la conservazione degli oggetti.
Puoi ottenere queste autorizzazioni anche con altri ruoli predefiniti o ruoli personalizzati.
Per informazioni sulla concessione dei ruoli nei bucket, consulta Utilizzare IAM con i bucket.
Trasmettere un caricamento in streaming
I seguenti esempi mostrano come eseguire un caricamento in modalità flusso da un processo a un oggetto Cloud Storage:
Console
La console Google Cloud non supporta i caricamenti in modalità flusso. Utilizza invece gcloud CLI.
Riga di comando
Reindirizza i dati al comando
gcloud storage cp
e utilizza un trattino per l'URL di origine:PROCESS_NAME | gcloud storage cp - gs://BUCKET_NAME/OBJECT_NAME
Dove:
PROCESS_NAME
è il nome del processo da cui vengono raccolti i dati. Ad esempio,collect_measurements
.BUCKET_NAME
è il nome del bucket che contiene l'oggetto. Ad esempio,my_app_bucket
.OBJECT_NAME
è il nome dell'oggetto creato a partire dai dati. Ad esempio,data_measurements
.
Librerie client
C++
Per maggiori informazioni, consulta la documentazione di riferimento dell'API C++ di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura Credenziali predefinite dell'applicazione. Per maggiori informazioni, consulta Configurare l'autenticazione per un ambiente di sviluppo locale.
C#
Per maggiori informazioni, consulta la documentazione di riferimento dell'API C# di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura Credenziali predefinite dell'applicazione. Per maggiori informazioni, consulta Configurare l'autenticazione per un ambiente di sviluppo locale.
Go
Per maggiori informazioni, consulta la documentazione di riferimento dell'API Go di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura Credenziali predefinite dell'applicazione. Per maggiori informazioni, consulta Configurare l'autenticazione per un ambiente di sviluppo locale.
Java
Per maggiori informazioni, consulta la documentazione di riferimento dell'API Java di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura Credenziali predefinite dell'applicazione. Per maggiori informazioni, consulta Configurare l'autenticazione per un ambiente di sviluppo locale.
Node.js
Per maggiori informazioni, consulta la documentazione di riferimento dell'API Node.js di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura Credenziali predefinite dell'applicazione. Per maggiori informazioni, consulta Configurare l'autenticazione per un ambiente di sviluppo locale.
PHP
Per maggiori informazioni, consulta la documentazione di riferimento dell'API PHP di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura Credenziali predefinite dell'applicazione. Per maggiori informazioni, consulta Configurare l'autenticazione per un ambiente di sviluppo locale.
Python
Per maggiori informazioni, consulta la documentazione di riferimento dell'API Python di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura Credenziali predefinite dell'applicazione. Per maggiori informazioni, consulta Configurare l'autenticazione per un ambiente di sviluppo locale.
Ruby
Per maggiori informazioni, consulta la documentazione di riferimento dell'API Ruby di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura Credenziali predefinite dell'applicazione. Per maggiori informazioni, consulta Configurare l'autenticazione per un ambiente di sviluppo locale.
API REST
API JSON
Per eseguire un caricamento streaming, segui le istruzioni relative all'esecuzione di un caricamento ripristinabile con le seguenti considerazioni:
Quando carichi i dati del file, utilizza il caricamento di più blocchi.
Poiché non conosci le dimensioni totali del file finché non arrivi al blocco finale, utilizza un
*
per le dimensioni totali del file nell'intestazioneContent-Range
dei blocchi intermedi.Ad esempio, se il primo blocco caricato ha una dimensione di 512 KiB, l'intestazione
Content-Range
del blocco èbytes 0-524287/*
. Se il caricamento ha 64.000 byte rimanenti dopo il primo blocco, invii un blocco finale che contiene i byte rimanenti e ha un'intestazioneContent-Range
con il valorebytes 524288-588287/588288
.
API XML
Per eseguire un caricamento in streaming, utilizza uno dei seguenti metodi:
Un caricamento ripristinabile, con le seguenti modifiche:
Quando carichi i dati del file, utilizza il caricamento di più blocchi.
Poiché non conosci le dimensioni totali del file finché non arrivi al blocco finale, utilizza un
*
per le dimensioni totali del file nell'intestazioneContent-Range
dei blocchi intermedi.Ad esempio, se il primo blocco caricato ha una dimensione di 512 KiB, l'intestazione
Content-Range
del blocco èbytes 0-524287/*
. Se dopo il primo blocco rimangono 64.000 byte per il caricamento, invierai un blocco finale che contiene i byte rimanenti e ha un'intestazioneContent-Range
con il valorebytes 524288-588287/588288
.
Passaggi successivi
- Riprodurre in streaming un download.
- Scopri di più sulla transcodifica decompressiva.
- Scopri di più su caricamenti e download.