Cloud Storage supports streaming data to a bucket without requiring that the data first be saved to a file. This is useful when you want to upload data but don't know the final size at the start of the upload, such as when generating the upload data from a process, or when compressing an object on-the-fly.
Using checksum validation when streaming
Because a checksum can only be supplied in the initial request of an upload, it's often not feasible to use Cloud Storage's checksum validation when streaming. It's recommended that you always use checksum validation, and you can manually do so after a streaming upload completes; however, validating after the transfer completes means that any corrupted data is accessible during the time it takes to confirm the corruption and remove it.
If you require checksum validation prior to the upload completing and the data becoming accessible, then you shouldn't use a streaming upload. You should use a different upload option that performs checksum validation prior to finalizing the object.
Required roles
To get the permissions that you need to stream uploads, ask your administrator to grant you one of the following roles:
- For uploads that include an Object Retention Lock, ask your administrator to grant you the Storage Object Admin ( - roles/storage.objectAdmin) IAM role for the bucket.
- For all other cases, ask your administrator to grant you the Storage Object User ( - roles/storage.objectUser) IAM role for the bucket.
These predefined roles contain the permissions required to stream uploads to Cloud Storage. To see the exact permissions that are required, expand the Required permissions section:
Required permissions
- storage.objects.create
- storage.objects.delete
- This permission is only required for uploads that overwrite an existing object.
- storage.objects.list
- This permission is only required for using the Google Cloud CLI to perform the instructions on this page.
- storage.objects.setRetention- This permission is only required for uploads that include an Object Retention Lock.
 
You can also get these permissions with other predefined roles or custom roles.
For information about granting roles on buckets, see Set and manage IAM policies on buckets.
Stream an upload
The following examples show how to perform a streaming upload from a process to a Cloud Storage object:
Console
The Google Cloud console does not support streaming uploads. Use the gcloud CLI instead.
Command line
- Pipe the data to the - gcloud storage cpcommand and use a dash for the source URL:- PROCESS_NAME | gcloud storage cp - gs://BUCKET_NAME/OBJECT_NAME - Where: - PROCESS_NAMEis the name of the process from which you are collecting data. For example,- collect_measurements.
- BUCKET_NAMEis the name of the bucket containing the object. For example,- my_app_bucket.
- OBJECT_NAMEis the name of the object that is created from the data. For example,- data_measurements.
 
Client libraries
  
  
  
    
  
 
      
      
  For more information, see the
  Cloud Storage C++ API
    reference documentation.
  
     
      To authenticate to Cloud Storage, set up Application Default Credentials.
      For more information, see
      
        Set up authentication for client libraries.
      
     
      
      
  For more information, see the
  Cloud Storage C# API
    reference documentation.
  
     
      To authenticate to Cloud Storage, set up Application Default Credentials.
      For more information, see
      
        Set up authentication for client libraries.
      
     
      
      
  For more information, see the
  Cloud Storage Go API
    reference documentation.
  
     
      To authenticate to Cloud Storage, set up Application Default Credentials.
      For more information, see
      
        Set up authentication for client libraries.
      
     
      
      
  For more information, see the
  Cloud Storage Java API
    reference documentation.
  
     
      To authenticate to Cloud Storage, set up Application Default Credentials.
      For more information, see
      
        Set up authentication for client libraries.
      
     
      
      
  For more information, see the
  Cloud Storage Node.js API
    reference documentation.
  
     
      To authenticate to Cloud Storage, set up Application Default Credentials.
      For more information, see
      
        Set up authentication for client libraries.
      
     
      
      
  For more information, see the
  Cloud Storage PHP API
    reference documentation.
  
     
      To authenticate to Cloud Storage, set up Application Default Credentials.
      For more information, see
      
        Set up authentication for client libraries.
      
     
      
      
  For more information, see the
  Cloud Storage Python API
    reference documentation.
  
     
      To authenticate to Cloud Storage, set up Application Default Credentials.
      For more information, see
      
        Set up authentication for client libraries.
      
     
      
      
  For more information, see the
  Cloud Storage Ruby API
    reference documentation.
  
     
      To authenticate to Cloud Storage, set up Application Default Credentials.
      For more information, see
      
        Set up authentication for client libraries.
      
    C++
  
  
    
    C#
  
  
    
    Go
  
  
    
    Java
  
  
    
    Node.js
  
  
    
    PHP
  
  
    
    Python
  
  
    
    Ruby
  
  
    
    
REST APIs
JSON API
To perform a streaming upload, use one of the following methods:
- A resumable upload, with the following adjustments: - When uploading the file data itself, use a multiple chunk upload. 
- Since you don't know the total file size until you get to the final chunk, use a - *for the total file size in the- Content-Rangeheader of intermediate chunks.- For example, if the first chunk you upload has a size of 512 KiB, the - Content-Rangeheader for the chunk is- bytes 0-524287/*. If your upload has 64000 bytes remaining after the first chunk, you then send a final chunk that contains the remaining bytes and has a- Content-Rangeheader with the value- bytes 524288-588287/588288.
 
- A single-request upload, with the following adjustments: - Include a - Transfer-Encoding: chunkedheader, and exclude the- Content-Lengthheader.
- Construct the request according to the specification, sending the object data in chunks as it becomes available. 
 
XML API
To perform a streaming upload, use one of the following methods:
- A resumable upload, with the following adjustments: - When uploading the file data itself, use a multiple chunk upload. 
- Since you don't know the total file size until you get to the final chunk, use a - *for the total file size in the- Content-Rangeheader of intermediate chunks.- For example, if the first chunk you upload has a size of 512 KiB, the - Content-Rangeheader for the chunk is- bytes 0-524287/*. If your upload has 64000 bytes remaining after the first chunk, you then send a final chunk that contains the remaining bytes and has a- Content-Rangeheader with the value- bytes 524288-588287/588288.
 
- A single-request upload, with the following adjustments: - Include a - Transfer-Encoding: chunkedheader, and exclude the- Content-Lengthheader.
- Construct the request according to the specification, sending the object data in chunks as it becomes available. 
- Note that you cannot perform a streaming upload using this method if the request uses a signature in its - Authorizationheader.
 
What's next
- Stream a download.
- Learn more about decompressive transcoding.
- Learn more about uploads and downloads.