

# AWS CLI および SDK for Java を使用したライフサイクル設定の作成と管理
<a name="S3OutpostsLifecycleCLIJava"></a>

S3 ライフサイクルを使用して、Amazon S3 on Outposts のストレージ容量を最適化することができます。ライフサイクルルールを作成して、オブジェクトが古くなったり、新しいバージョンに置き換えられたりしたときに期限切れにすることができます。ライフサイクルルールを作成、有効化、無効化、または削除できます。

S3 ライフサイクルの詳細については、「[Amazon S3 on Outposts バケットのライフサイクル設定を作成および管理する](S3OutpostsLifecycleManaging.md)」を参照してください。

**注記**  
バケットを作成する AWS アカウント がそのバケットを所有し、ライフサイクルルールを作成、有効化、無効化、または削除できる唯一のアカウントです。

AWS Command Line Interface (AWS CLI) と AWS SDK for Java を使用して S3 on Outposts バケット用のライフサイクル設定を作成および管理するには、以下の例を参照してください。

**Topics**
+ [ライフサイクル設定を PUT する](#S3OutpostsPutBucketLifecycleConfiguration)
+ [S3 on Outposts バケットのライフサイクル設定を GET する](#S3OutpostsGetBucketLifecycleConfiguration)

## ライフサイクル設定を PUT する
<a name="S3OutpostsPutBucketLifecycleConfiguration"></a>

------
#### [ AWS CLI ]

次の AWS CLI の例では、Outposts バケットにライフサイクル設定ポリシーを配置します。このポリシーでは、フラグ付きのプレフィックス (`{{myprefix}}`) とタグを持つすべてのオブジェクトが 10 日後に期限切れになることを指定します。この例を実行するには、それぞれの `{{user input placeholder}}` をユーザー自身の情報に置き換えます。

1. ライフサイクル設定ポリシーを JSON ファイルに保存します。この例では、ファイル名は `lifecycle1.json` です。

   ```
   {
       "Rules": [
           {
               "ID": "{{id-1}}",
               "Filter": {
                   "And": {
                       "Prefix": "{{myprefix}}", 
                       "Tags": [
                           {
                               "Value": "{{mytagvalue1}}", 
                               "Key": "{{mytagkey1}}"
                           }, 
                           {
                               "Value": "{{mytagvalue2}}", 
                               "Key": "{{mytagkey2}}"
                           }
                       ],
                       "ObjectSizeGreaterThan": {{1000}},
                       "ObjectSizeLessThan": {{5000}}
                   }
               }, 
               "Status": "{{Enabled}}", 
               "Expiration": {
                   "Days": {{10}}
               }
           }
       ]
   }
   ```

1. `put-bucket-lifecycle-configuration` CLI コマンドの一部として JSON ファイルを送信します。このコマンドを使用するには、それぞれの `{{user input placeholder}}` をユーザー自身の情報に置き換えます。このコマンドの詳細については、「*AWS CLI リファレンス*」の「[put-bucket-lifecycle-configuration](https://awscli.amazonaws.com/v2/documentation/api/latest/reference/s3control/put-bucket-lifecycle-configuration.html)」を参照してください。

   ```
   aws s3control put-bucket-lifecycle-configuration --account-id {{123456789012}} --bucket arn:aws:s3-outposts:{{region}}:{{123456789012}}:outpost/{{op-01ac5d28a6a232904}}/bucket/{{example-outposts-bucket}} --lifecycle-configuration file://{{lifecycle1.json}}
   ```

------
#### [ SDK for Java ]

次の SDK for Java の例では、Outposts バケットにライフサイクル設定を配置します。このライフサイクル設定では、フラグ付きのプレフィックス (`{{myprefix}}`) とタグを持つすべてのオブジェクトが 10 日後に期限切れになることを指定します。この例を実行するには、それぞれの `{{user input placeholder}}` をユーザー自身の情報に置き換えます。詳細については、「*Amazon S3 API リファレンス*」の「[PutBucketLifecycleConfiguration](https://docs.aws.amazon.com/AmazonS3/latest/API/API_control_PutBucketLifecycleConfiguration.html)」を参照してください。

```
import com.amazonaws.services.s3control.model.*;

public void putBucketLifecycleConfiguration(String bucketArn) {

    S3Tag tag1 = new S3Tag().withKey({{"mytagkey1"}}).withValue({{"mytagkey1"}});
    S3Tag tag2 = new S3Tag().withKey({{"mytagkey2"}}).withValue({{"mytagkey2"}});

    LifecycleRuleFilter lifecycleRuleFilter = new LifecycleRuleFilter()
            .withAnd(new LifecycleRuleAndOperator()
                    .withPrefix({{"myprefix"}})
                    .withTags(tag1, tag2))
                    .withObjectSizeGreaterThan({{1000}})
                    .withObjectSizeLessThan({{5000}});

    LifecycleExpiration lifecycleExpiration = new LifecycleExpiration()
            .withExpiredObjectDeleteMarker({{false}})
            .withDays({{10}});

    LifecycleRule lifecycleRule = new LifecycleRule()
            .withStatus({{"Enabled"}})
            .withFilter(lifecycleRuleFilter)
            .withExpiration(lifecycleExpiration)
            .withID({{"id-1"}});

    LifecycleConfiguration lifecycleConfiguration = new LifecycleConfiguration()
            .withRules(lifecycleRule);

    PutBucketLifecycleConfigurationRequest reqPutBucketLifecycle = new PutBucketLifecycleConfigurationRequest()
            .withAccountId(AccountId)
            .withBucket(bucketArn)
            .withLifecycleConfiguration(lifecycleConfiguration);

    PutBucketLifecycleConfigurationResult respPutBucketLifecycle = s3ControlClient.putBucketLifecycleConfiguration(reqPutBucketLifecycle);
    System.out.printf("PutBucketLifecycleConfiguration Response: %s%n", respPutBucketLifecycle.toString());

}
```

------

## S3 on Outposts バケットのライフサイクル設定を GET する
<a name="S3OutpostsGetBucketLifecycleConfiguration"></a>

------
#### [ AWS CLI ]

次の AWS CLI の例では、Outposts バケットにライフサイクル設定を取得します。このコマンドを使用するには、それぞれの `{{user input placeholder}}` をユーザー自身の情報に置き換えます。このコマンドの詳細については、「*AWS CLI リファレンス*」の「[put-bucket-lifecycle-configuration](https://awscli.amazonaws.com/v2/documentation/api/latest/reference/s3control/get-bucket-lifecycle-configuration.html)」を参照してください。

```
aws s3control get-bucket-lifecycle-configuration --account-id {{123456789012}} --bucket arn:aws:s3-outposts:{{<your-region>}}:{{123456789012}}:outpost/{{op-01ac5d28a6a232904}}/bucket/{{example-outposts-bucket}}
```

------
#### [ SDK for Java ]

次の SDK for Java の例では、Outposts バケットにライフサイクル設定を取得します。詳細については、「*Amazon Simple Storage Service API リファレンス*」の「[GetBucketLifecycleConfiguration](https://docs.aws.amazon.com/AmazonS3/latest/API/API_control_GetBucketLifecycleConfiguration.html)」を参照してください。

```
import com.amazonaws.services.s3control.model.*;

public void getBucketLifecycleConfiguration(String bucketArn) {

    GetBucketLifecycleConfigurationRequest reqGetBucketLifecycle = new GetBucketLifecycleConfigurationRequest()
            .withAccountId(AccountId)
            .withBucket(bucketArn);

    GetBucketLifecycleConfigurationResult respGetBucketLifecycle = s3ControlClient.getBucketLifecycleConfiguration(reqGetBucketLifecycle);
    System.out.printf("GetBucketLifecycleConfiguration Response: %s%n", respGetBucketLifecycle.toString());

}
```

------