Bucket Lifecycle
The lifecycle configuration allow you to set an expiration policy on your objects and auto-delete them.
For example, you may need for some objects to be deleted automatically.
In this example, we will automatically create a policy to delete objects with a key starting with reports/
after 90 days. We could use a GUI Client or AWS SDK, but we will use AWS CLI to do so.
Limitations
Lifecycle is a bucket level concept.
Maximum of 1000 lifecycle rules per bucket is applicable.
There may be a delay between the expiration date and the date at which Object Storage Service removes an object.
Always round up the resulting time to the next day midnight UTC.
Deleted Object cannot be restored.
Manage lifecycle policy
Bucket lifecycle configuration can be managed using aws s3api (other tools or SDK works too):
put-bucket-lifecycle
get-bucket-lifecycle
delete-bucket-lifecycle
We use aws s3 and **aws s3api
**command line tools from AWSCLIv2 on Linux.
${S3_ENDPOINT}
& ${S3_PROFILE}
are environment variables.
Create a lifecycle policy
Create JSON file and put your policy in it:
Apply it to the bucket: bucket-test
Get a lifecycle configuration
Delete a lifecycle configuration
Supported lifecycle configuration elements
And
Container for specify rule filters. These filters determine the subset of objects to which the rule applies.
Type: String
Ancestor:
Rule
Yes, if you specify more than one filter condition (for example, one prefix and one or more tags).
Date
Date when you want S3 to take the action.
The date value must conform to the ISO 8601 format. The time is always midnight UTC.
Type: String
Ancestor:
Expiration
Yes, if Days
and ExpiredObjectDeleteMarker
are absent.
Days
Specifies the number of days after object creation when the specific rule action takes effect.
Type: Nonnegative Integer when used with Transition, Positive Integer when used with Expiration.
Ancestor:
Expiration
Yes, if Date
and ExpiredObjectDeleteMarker
are absent.
Expiration
This action specifies a period in an object's lifetime when S3 should take the appropriate expiration action. The action S3 takes depends on whether the bucket is versioning-enabled.
If versioning has never been enabled on the bucket, S3 deletes the only copy of the object permanently. Otherwise, if your bucket is versioning-enabled (or versioning is suspended), the action applies only to the current version of the object. A versioning-enabled bucket can have many versions of the same object, one current version, and zero or more non-current versions.
Instead of deleting the current version, S3 makes it a non-current version by adding a delete marker as the new current version.
Note:
If your bucket state is versioning-suspended, S3 creates a delete marker with version ID null. If you have a version with version ID null, then S3 overwrites that version.
To set expiration for non-current objects, you must use the
NoncurrentVersionExpiration
action.
Type: Container
Children:
Days
orDate
Ancestor:
Rule
Yes, if no other action is present in the Rule.
Filter
Container for elements that describe the filter identifying a subset of objects to which the lifecycle rule applies. If you specify an empty filter (
"Prefix": {}
), the rule applies to all objects in the bucket.Type: String
Children:
Prefix
,Tag
Ancestor:
Rule
Yes
ID
Unique identifier for the rule. The value cannot be longer than 255 characters.
Type: String
Ancestor:
Rule
No
Key
Specifies the key of a tag. A tag key can be up to 128 Unicode characters in length.
Tag keys that you specify in a lifecycle rule filter must be unique.
Type: String
Ancestor:
Tag
Yes, if <
Tag
>
parent is specified.
LifecycleConfiguration
Container for lifecycle rules. You can add as many as 1,000 rules.
Type: Container
Children:
Rule
Ancestor: None
Yes
ExpiredObjectDeleteMarker
On a versioned bucket (versioning-enabled or versioning-suspended bucket), you can add this element in the lifecycle configuration to direct S3 to delete expired object delete markers. On a non-versioned bucket, adding this element in a policy is meaningless because you cannot have delete markers and the element does not do anything.
When you specify this lifecycle action, the rule cannot specify a tag-based filter.
Type: String
Valid values: true | false (the value false is allowed, but it is no-op and S3 does not take action if the value is false)
Ancestor:
Expiration
.
Yes, if Date
and Days
are absent.
NoncurrentDays
Specifies the number of days an object is non-current before S3 can perform the associated action.
Type: Positive Integer when used with
NoncurrentVersionExpiration
.Ancestor:
NoncurrentVersionExpiration
Yes
NoncurrentVersionExpiration
Specifies when non-current object versions expire. Upon expiration, S3 permanently deletes the non-current object versions.
You set this lifecycle configuration action on a bucket that has versioning enabled (or suspended) to request that S3 delete non-current object versions at a specific period in the object's lifetime.
Type: Container
Children:
NoncurrentDays
Ancestor:
Rule
Yes, if no other action is present in the Rule
.
Prefix
Object key prefix identifying one or more objects to which the rule applies. Empty prefix (<Prefix></Prefix>) indicates there is no filter based on key prefix.
Note:
Supports <Prefix> with and without <Filter>. (Deprecated)
"Prefix": "", # No Prefix "Prefix": "documents/",
PUT Bucket lifecycle with <Filter>
"Filter": { "Prefix": ""}"Filter": { "Prefix": "documents/"}
There can be at most one Prefix in a lifecycle rule Filter.
Type: String
Ancestor:
Filter
orAnd
(if you specify multiple filters such as a prefix and one or more tags)
No
"Prefix": "", # No Prefix "Prefix": "documents/",
"Filter": { "Prefix": ""}"Filter": { "Prefix": "documents/"}
Rule
Container for a lifecycle rule. A lifecycle configuration can contain as many as 1,000 rules.
Type: Container
Ancestor:
LifecycleConfiguration
Yes
Status
if Enabled, S3 executes the rule as scheduled. If Disabled, S3 ignores the rule.
Type: String
Ancestor:
Rule
Valid values: Enabled, Disabled.
Yes
Value
Specifies the value for a tag key. Each object tag is a key-value pair.
Tag value can be up to 256 Unicode characters in length.
Type: String
Ancestor:
Tag
Yes, if <
Tag
>
parent is specified.
Last updated