Cloud Storage supporta lo streaming dei dati in un bucket senza richiedere che i dati vengano prima salvati in un file. Questa funzionalità è 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 al volo.
Utilizzare la convalida del checksum durante lo streaming
Poiché un checksum può essere fornito solo nella richiesta iniziale di un caricamento, spesso non è fattibile utilizzare la convalida del checksum di Cloud Storage durante lo streaming. Ti consigliamo di utilizzare sempre la convalida del checksum, che puoi eseguire manualmente al termine di un caricamento in streaming. Tuttavia, la convalida al termine del trasferimento significa che tutti i dati danneggiati sono accessibili durante il tempo necessario per confermare il danneggiamento e rimuoverli.
Se hai bisogno della convalida del checksum prima del completamento del caricamento e che i dati diventino accessibili, non devi utilizzare un caricamento in streaming. 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 lo streaming dei caricamenti, chiedi all'amministratore di concederti uno dei seguenti ruoli:
Per i caricamenti che includono un blocco della conservazione degli oggetti, chiedi all' amministratore di concederti il ruolo IAM Amministratore oggetti Storage (
roles/storage.objectAdmin) per il bucket.In 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 lo streaming dei caricamenti in Cloud Storage. Per vedere quali sono esattamente le autorizzazioni richieste, espandi la sezione Autorizzazioni obbligatorie:
Autorizzazioni obbligatorie
storage.objects.createstorage.objects.delete- Questa autorizzazione è necessaria solo per i caricamenti che sovrascrivono un oggetto esistente.
storage.objects.list- Questa autorizzazione è necessaria solo per utilizzare Google Cloud CLI per eseguire le istruzioni riportate in questa pagina.
storage.objects.setRetention- Questa autorizzazione è necessaria solo per i caricamenti che includono un blocco della conservazione degli oggetti.
Puoi ottenere queste autorizzazioni anche con altri ruoli predefiniti o ruoli personalizzati.
Per informazioni sulla concessione dei ruoli nei bucket, consulta Impostare e gestire i criteri IAM nei bucket.
Eseguire lo streaming di un caricamento
Gli esempi riportati di seguito mostrano come eseguire un caricamento in streaming da un processo a un oggetto Cloud Storage:
Console
La Google Cloud console non supporta i caricamenti in streaming. Utilizza invece gcloud CLI.
Riga di comando
Invia i dati tramite pipe al comando
gcloud storage cpe 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 stai raccogliendo i dati. Ad esempio,collect_measurements.BUCKET_NAMEè il nome del bucket contenente l'oggetto. Ad esempio,my_app_bucket.OBJECT_NAMEè il nome dell'oggetto creato dai dati. Ad esempio,data_measurements.
Librerie client
C++
Per saperne di più, consulta la documentazione di riferimento dell'APIC++ di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
C#
Per saperne di più, consulta la documentazione di riferimento dell'C# API di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
Go
Per saperne di più, consulta la documentazione di riferimento dell' API Go di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
Java
Per saperne di più, consulta la documentazione di riferimento dell'API Java Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
Node.js
Per saperne di più, consulta la documentazione di riferimento dell'Node.js API di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
PHP
Per saperne di più, consulta la documentazione di riferimento dell'API PHP Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
Python
Per saperne di più, consulta la documentazione di riferimento dell' API Python di Cloud Storage.
Per eseguire l'autenticazione in Cloud Storage, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
Ruby
Per saperne di più, consulta la documentazione di riferimento dell'API Cloud Storage Ruby .
Per eseguire l'autenticazione in Cloud Storage, configura le Credenziali predefinite dell'applicazione. Per saperne di più, vedi Configura l'autenticazione per le librerie client.
Rust
API REST
API JSON
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 un caricamento di più blocchi.
Poiché non conosci le dimensioni totali del file fino all'ultimo blocco, utilizza un
*per le dimensioni totali del file nell'intestazioneContent-Rangedei blocchi intermedi.Ad esempio, se il primo blocco che carichi ha una dimensione di 512 KiB, l'intestazione
Content-Rangedel blocco èbytes 0-524287/*. Se dopo il primo blocco rimangono 64.000 byte da caricare, invia un blocco finale che contiene i byte rimanenti e ha un'intestazioneContent-Rangecon il valorebytes 524288-588287/588288.
Un caricamento con una singola richiesta, con le seguenti modifiche:
Includi un'
Transfer-Encoding: chunkedheader ed escludi l'Content-Lengthheader.Costruisci la richiesta in base alla specifica, inviando i dati dell'oggetto in blocchi man mano che diventano disponibili.
API XML
Per eseguire un caricamento in streaming, utilizza uno dei seguenti metodi:
Un caricamento in più parti dell'API XML
Un caricamento ripristinabile, con le seguenti modifiche:
Quando carichi i dati del file, utilizza un caricamento di più blocchi.
Poiché non conosci le dimensioni totali del file fino all'ultimo blocco, utilizza un
*per le dimensioni totali del file nell'intestazioneContent-Rangedei blocchi intermedi.Ad esempio, se il primo blocco che carichi ha una dimensione di 512 KiB, l'intestazione
Content-Rangedel blocco èbytes 0-524287/*. Se dopo il primo blocco rimangono 64.000 byte da caricare, invia un blocco finale che contiene i byte rimanenti e ha un'intestazioneContent-Rangecon il valorebytes 524288-588287/588288.
Un caricamento con una singola richiesta, con le seguenti modifiche:
Includi un'
Transfer-Encoding: chunkedheader ed escludi l'Content-Lengthheader.Costruisci la richiesta in base alla specifica, inviando i dati dell'oggetto in blocchi man mano che diventano disponibili.
Tieni presente che non puoi eseguire un caricamento in streaming utilizzando questo metodo se la richiesta utilizza una firma nella sua
Authorizationintestazione.
Passaggi successivi
- Eseguire lo streaming di un download.
- Scopri di più sulla transcodifica decompressiva.
- Scopri di più sui caricamenti di oggetti.