0
0
GCPcloud~10 mins

Object versioning in GCP - Step-by-Step Execution

Choose your learning style9 modes available
Process Flow - Object versioning
Enable Versioning on Bucket
Upload Object (v1)
Upload Object (v2)
List Object Versions
Access Specific Version
Delete Specific Version or All Versions
This flow shows enabling versioning on a storage bucket, uploading multiple versions of an object, listing versions, accessing specific versions, and deleting versions.
Execution Sample
GCP
gsutil versioning set on gs://my-bucket
 gsutil cp file.txt gs://my-bucket/file.txt
 gsutil cp file_v2.txt gs://my-bucket/file.txt
 gsutil ls -a gs://my-bucket/file.txt
Enable versioning on a bucket, upload two versions of the same file, then list all versions.
Process Table
StepActionBucket Versioning StateObject NameVersion IDResult
1Enable versioning on bucketEnabled--Bucket versioning enabled
2Upload file.txt as file.txtEnabledfile.txtv1Object uploaded as version v1
3Upload file_v2.txt as file.txtEnabledfile.txtv2New version v2 created, old version v1 retained
4List all versions of file.txtEnabledfile.txtv1, v2Both versions listed
5Access version v1Enabledfile.txtv1Version v1 content retrieved
6Delete version v2Enabledfile.txtv2Version v2 deleted, version v1 remains
7Delete version v1Enabledfile.txtv1Version v1 deleted, no versions remain
8List all versions after deletionsEnabledfile.txt-No versions found
9Upload new file.txtEnabledfile.txtv3New version v3 created
10Disable versioning on bucketSuspended--Bucket versioning suspended
11Upload file.txt againSuspendedfile.txt-Object overwritten, no versioning
12List versions after suspensionSuspendedfile.txtv3Only version v3 exists, no new versions created
13End---Process complete
💡 Versioning stops creating new versions after suspension; existing versions remain until deleted.
Status Tracker
VariableStartAfter Step 2After Step 3After Step 6After Step 7After Step 9After Step 10After Step 11
Bucket Versioning StateSuspendedEnabledEnabledEnabledEnabledEnabledSuspendedSuspended
file.txt VersionsNonev1v1, v2v1Nonev3v3v3
Key Moments - 3 Insights
Why do old versions remain after uploading a new version?
Because versioning is enabled (see steps 2 and 3), each upload creates a new version without deleting old ones.
What happens when versioning is suspended and a file is uploaded again?
No new versions are created; the existing object is overwritten (see steps 10 and 11).
How can you access a specific version of an object?
By specifying the version ID when accessing the object, as shown in step 5.
Visual Quiz - 3 Questions
Test your understanding
Look at the execution table, what is the bucket versioning state after step 10?
ASuspended
BEnabled
CDisabled
DUnknown
💡 Hint
Check the 'Bucket Versioning State' column at step 10 in the execution table.
At which step are both versions v1 and v2 present?
AStep 2
BStep 3
CStep 6
DStep 7
💡 Hint
Look at the 'file.txt Versions' column in the variable tracker and execution table rows.
If versioning was never enabled, what would happen when uploading file.txt twice?
ATwo versions would be created
BAn error would occur
COnly the latest file would exist, overwriting the previous
DThe file would be duplicated with different names
💡 Hint
Refer to steps 10 and 11 where versioning is suspended and uploads overwrite.
Concept Snapshot
Object Versioning in GCP Storage:
- Enable versioning on a bucket to keep old object versions.
- Each upload creates a new version with a unique ID.
- List versions with 'gsutil ls -a'.
- Access or delete specific versions by ID.
- Suspending versioning stops new versions but keeps old ones.
Full Transcript
Object versioning in Google Cloud Storage lets you keep multiple versions of the same file. First, you enable versioning on a bucket. Then, every time you upload a file with the same name, a new version is created instead of overwriting. You can list all versions and access or delete any specific version. If you suspend versioning, new uploads overwrite the existing file without creating new versions, but old versions remain until deleted. This helps protect against accidental deletion or overwrites by keeping history.