Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 9 Next »

At the cluster setting level, a user must enable lifecycle policies. As it is enabled in the cluster, so use the management API:

curl -X PUT --header 'Content-Type: application/json' --header 'Accept: text/plain' -d '{}'
'http://lucky1.tx.caringo.com:91/api/storage/clusters/_self/settings/policy.lifecycle?value=enabled' -u admin:ourpwdofchoicehere

A missing Policy-Lifecycle header on the domain is considered a tacit enablement so it is not required to make any changes.

A bucket may have one or multiple lifecycle policies, such as:

  • Expire all versioned content after one year

  • Expire all current content after 5 years, etc.

Such policies are applied on a bucket object using one or multiple Policy-Lifecycle headers:

curl –X COPY –-post301 –-location-trusted –H 'Policy-Lifecycle: RuleId:"rule5" ExpirationDays:1825 ObsoleteExpirationDays:365'
'http://lucky1.tx.caringo.com/mybucket?domain=mydomain&preserve'

In the previous example, implicitly applying to all content in the bucket by;

  • Naming the single policy

  • Not declaring it enabled (as it is by default)

  • Relying on a missing prefix

The preserve query argument on the COPY operations indicates leaving other persisted headers as they are.

[root@test ~]# aws s3api get-bucket-lifecycle --endpoint "http://dom-lifecycle1.ro:8090" --bucket b1
{
    "Rules": [
        {
            "Expiration": {
                "Days": 1
            },
            "ID": "Rule5",
            "Status": "Enabled"
        }
    ]
}
[root@test ~]# vi lifecycle.json
[root@test ~]#
[root@test ~]#
[root@test ~]#
[root@test ~]#
[root@test ~]# cat lifecycle.json
{
        "Rules": [
                {
                        "ID": "Rule6",
                        "Status": "Enabled",
                        "Expiration": { "Days": 5 }
                }
        ]
}
[root@test ~]# aws s3api put-bucket-lifecycle-configuration --endpoint "http://dom-lifecycle1.ro:8090" --bucket b1 --lifecycle-configuration file://lifecycle.json
[root@test ~]# aws s3api get-bucket-lifecycle --endpoint "http://dom-lifecycle1.ro:8090" --bucket b1
{
    "Rules": [
        {
            "Expiration": {
                "Days": 1
            },
            "ID": "Rule5",
            "Status": "Enabled"
        },
        {
            "Expiration": {
                "Days": 5
            },
            "ID": "Rule6",
            "Status": "Enabled"
        }
    ]
}

Important
Re-transmit all Policy-Lifecycle headers to make them appear on the new object. It is recommended to use Content UI for editing policy rules.

See S3 lifecycle policy examples. Note that Swarm currently only supports expiration policies.

  • No labels