Bird
Raised Fist0
GCPcloud~5 mins

Lifecycle management rules in GCP - Time & Space Complexity

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Time Complexity: Lifecycle management rules
O(n)
Understanding Time Complexity

We want to understand how the time to apply lifecycle management rules changes as we manage more storage objects.

Specifically, how does the number of objects affect the work done by these rules?

Scenario Under Consideration

Analyze the time complexity of applying lifecycle rules to objects in a Cloud Storage bucket.

// Define lifecycle rule for a bucket
storageClient.buckets().patch(bucketName, {
  lifecycle: {
    rule: [
      { action: { type: 'Delete' }, condition: { age: 30 } }
    ]
  }
}).execute();

This sequence sets a rule to delete objects older than 30 days in a bucket.

Identify Repeating Operations

When lifecycle rules run, they check each object in the bucket.

  • Primary operation: Checking each object's metadata against the lifecycle conditions.
  • How many times: Once per object in the bucket.
How Execution Grows With Input

As the number of objects grows, the system checks more objects one by one.

Input Size (n)Approx. Checks
1010 checks
100100 checks
10001000 checks

Pattern observation: The number of checks grows directly with the number of objects.

Final Time Complexity

Time Complexity: O(n)

This means the time to apply lifecycle rules grows in direct proportion to the number of objects.

Common Mistake

[X] Wrong: "Lifecycle rules run instantly no matter how many objects exist."

[OK] Correct: Each object must be checked, so more objects mean more work and more time.

Interview Connect

Understanding how lifecycle rules scale helps you design storage solutions that stay efficient as data grows.

Self-Check

"What if lifecycle rules included multiple conditions and actions? How would that affect the time complexity?"

Practice

(1/5)
1. What is the main purpose of lifecycle management rules in Google Cloud Storage?
easy
A. To encrypt files before uploading
B. To manually upload files to the cloud storage
C. To create backups of files every hour
D. To automatically delete or move files based on conditions like age or storage class

Solution

  1. Step 1: Understand lifecycle rules function

    Lifecycle rules automate file management by applying actions like deletion or moving files based on set conditions.
  2. Step 2: Compare options with lifecycle purpose

    Only To automatically delete or move files based on conditions like age or storage class describes automatic file management based on age or storage class, which matches lifecycle rules.
  3. Final Answer:

    To automatically delete or move files based on conditions like age or storage class -> Option D
  4. Quick Check:

    Lifecycle rules automate file management = A [OK]
Hint: Lifecycle rules automate file cleanup and movement [OK]
Common Mistakes:
  • Confusing lifecycle rules with manual file upload
  • Thinking lifecycle rules create backups
  • Assuming lifecycle rules handle encryption
2. Which of the following is the correct syntax snippet to define a lifecycle rule that deletes objects older than 30 days in a GCP bucket JSON configuration?
easy
A. {"rules": [{"action": {"type": "Delete"}, "condition": {"age": 30}}]}
B. {"rule": [{"action": {"type": "Remove"}, "condition": {"age": 30}}]}
C. {"rule": [{"action": {"type": "Delete"}, "condition": {"age": 30}}]}
D. {"rule": [{"action": {"type": "Delete"}, "condition": {"days": 30}}]}

Solution

  1. Step 1: Identify correct key names in lifecycle JSON

    The lifecycle configuration uses the key "rules" (plural) for the list of rules, not "rule".
  2. Step 2: Check action type and condition keys

    Action type must be "Delete" and condition uses "age" in days. {"rules": [{"action": {"type": "Delete"}, "condition": {"age": 30}}]} correctly uses "rules", "Delete", and "age".
  3. Final Answer:

    {"rules": [{"action": {"type": "Delete"}, "condition": {"age": 30}}]} -> Option A
  4. Quick Check:

    Correct lifecycle JSON uses "rules" and "age" = C [OK]
Hint: Use "rules" key and "age" condition for lifecycle JSON [OK]
Common Mistakes:
  • Using singular "rule" instead of "rules"
  • Using "Remove" instead of "Delete" for action
  • Using "days" instead of "age" in condition
3. Given this lifecycle rule JSON snippet for a GCP bucket:
{"rules": [{"action": {"type": "SetStorageClass", "storageClass": "NEARLINE"}, "condition": {"age": 60}}]}

What happens to objects older than 60 days?
medium
A. They remain in the current storage class
B. They are deleted immediately
C. They are moved to the NEARLINE storage class
D. They are archived to Coldline storage

Solution

  1. Step 1: Understand action type in lifecycle rule

    The action type "SetStorageClass" changes the storage class of objects matching the condition.
  2. Step 2: Analyze condition and effect

    The condition "age": 60 means objects older than 60 days will be moved to the "NEARLINE" storage class.
  3. Final Answer:

    They are moved to the NEARLINE storage class -> Option C
  4. Quick Check:

    SetStorageClass action moves objects = A [OK]
Hint: SetStorageClass moves files; Delete removes them [OK]
Common Mistakes:
  • Confusing SetStorageClass with Delete action
  • Assuming objects are deleted instead of moved
  • Thinking NEARLINE means Coldline storage
4. You wrote this lifecycle rule JSON to delete objects older than 90 days:
{"rule": [{"action": {"type": "Delete"}, "condition": {"age": 90}}]}

Why does this rule not work as expected?
medium
A. The key should be "rules" not "rule"
B. The action type "Delete" is invalid
C. The condition "age" must be a string, not a number
D. The age value must be less than 30

Solution

  1. Step 1: Check lifecycle JSON key names

    The lifecycle configuration requires the key "rules" (plural) for the list of rules, not "rule".
  2. Step 2: Validate action and condition correctness

    "Delete" is a valid action type, and "age" is correctly a number. Age can be any positive number.
  3. Final Answer:

    The key should be "rules" not "rule" -> Option A
  4. Quick Check:

    Correct key is "rules" = B [OK]
Hint: Use "rules" key for lifecycle rules array [OK]
Common Mistakes:
  • Using singular "rule" instead of "rules"
  • Thinking "Delete" is invalid action
  • Believing age must be string or less than 30
5. You want to create a lifecycle rule that moves objects to Coldline storage after 30 days and deletes them after 365 days. Which JSON configuration correctly implements this?
hard
A. {"rules": [{"action": {"type": "SetStorageClass", "storageClass": "COLDLINE"}, "condition": {"age": 365}}, {"action": {"type": "Delete"}, "condition": {"age": 30}}]}
B. {"rules": [{"action": {"type": "SetStorageClass", "storageClass": "COLDLINE"}, "condition": {"age": 30}}, {"action": {"type": "Delete"}, "condition": {"age": 365}}]}
C. {"rules": [{"action": {"type": "SetStorageClass", "storageClass": "NEARLINE"}, "condition": {"age": 30}}, {"action": {"type": "Delete"}, "condition": {"age": 365}}]}
D. {"rules": [{"action": {"type": "Delete"}, "condition": {"age": 30}}, {"action": {"type": "SetStorageClass", "storageClass": "COLDLINE"}, "condition": {"age": 365}}]}

Solution

  1. Step 1: Identify correct order of lifecycle actions

    Objects should first move to Coldline after 30 days, then be deleted after 365 days. The order matters for correct lifecycle behavior.
  2. Step 2: Check storage class and age conditions

    {"rules": [{"action": {"type": "SetStorageClass", "storageClass": "COLDLINE"}, "condition": {"age": 30}}, {"action": {"type": "Delete"}, "condition": {"age": 365}}]} correctly sets "SetStorageClass" to "COLDLINE" at age 30, then "Delete" at age 365.
  3. Final Answer:

    {"rules": [{"action": {"type": "SetStorageClass", "storageClass": "COLDLINE"}, "condition": {"age": 30}}, {"action": {"type": "Delete"}, "condition": {"age": 365}}]} -> Option B
  4. Quick Check:

    Move to Coldline at 30 days, delete at 365 days = D [OK]
Hint: Order rules: move storage first, then delete later [OK]
Common Mistakes:
  • Reversing delete and move actions order
  • Using wrong storage class name
  • Setting wrong age values for actions