メインコンテンツまでスキップ
バージョン: User Guides (Cloud)

AWS S3 との統合

Zilliz Cloud では、Amazon Simple Storage Service (Amazon S3) と統合して、バックアップファイルや監査ログを指定の S3 バケットにエクスポートできます。

BUEcwkZiChJrTlbziBMc3V49nFe

開始前の準備

  • Zilliz Cloud と AWS S3 を統合するには、プロジェクトへの 組織オーナー または プロジェクト管理者 アクセス権が必要です。必要な権限がない場合は、Zilliz Cloud の 組織オーナー にお問い合わせください。

  • AWS Management Console への管理アクセス権を持っていること。

ステップ 1: Zilliz Cloud コンソールで統合を開始する

1

Zilliz Cloud コンソールにログインします。

2

プロジェクトページで、左側のナビゲーションペインから Integrations に移動します。

3

Amazon S3 セクションで、+ Integration をクリックします。

4

表示されたダイアログボックスで、基本設定 を構成します:

  • 統合名: この統合の一意の名前(例:integration_0819)。

  • 統合の説明 (オプション): この統合の説明(例:for export backupfile)。

  • バケット Permission: Zilliz Cloud が S3 バケットに対して持つアクセスレベルを選択します。以下の表で各オプションを説明します。

    Permission

    Description

    Read only

    Zilliz Cloud はバケットからファイルを読み取ることのみができます。外部コレクションをバックアップする外部ボリュームに使用します。

    Read write

    Zilliz Cloud はバケットへの読み取りと書き込みの両方ができます。バックアップエクスポート監査ログ転送、または アクセスログ転送に使用します。

5

Next をクリックします。Create Amazon S3 バケット ステップにリダイレクトされます:

  1. Zilliz Cloud Cluster Region フィールドで、Zilliz Cloud クラスターまたは外部ボリュームが存在するクラウドリージョンを選択します。後で作成するバケットは、Zilliz Cloud クラスターまたはボリュームと同じリージョンに存在する必要があります。

  2. S3 コンソールを開き、ステップ 2 に進みます。

ステップ 2: AWS コンソールで S3 バケットを作成する

1

Amazon S3 コンソールの右上隅で、Zilliz Cloud クラスターまたは外部ボリュームのリージョンと一致する AWS リージョンを選択します。

📘Notes
  • バケットを作成する AWS リージョンは、Zilliz Cloud クラスターまたは外部ボリュームが存在するリージョンと一致している必要があります。Zilliz Cloud でサポートされているリージョンについては、クラウドプロバイダーs & Regions を参照してください。

  • 異なるリージョンで実行されているクラスターの場合、バックアップファイルや監査ログが適切にエクスポートされるよう、各リージョンに対して個別の統合を作成してください。

2

左側のナビゲーションペインで 汎用バケット を選択し、Create bucket をクリックします。

3

バケット設定を構成します:

  1. バケットタイプ汎用 を選択します。

  2. バケット名 には、バケットの名前を入力します(例:zilliz-bucket-for-integration-0819)。このバケット名は後のステップで必要になるため、覚えておいてください。

  3. その他の設定はデフォルトのままにして、Create bucket をクリックします。

詳細については、バケットの作成 を参照してください。

バケットの作成が完了したら、Zilliz Cloud コンソールに戻り、以下を実行します:

1

バケット名 フィールドに、先ほど作成したバケットの名前を入力します(この例では zilliz-bucket-for-integration-0819)。次に、Next をクリックします。

2

Create IAM Policy ステップで、JSON ポリシーをコピーします。これは ステップ 3 で必要になります。

3

完了したら、IAM コンソールを開き、ステップ 3 に進みます。

ステップ 3: AWS コンソールで IAM ポリシーを作成する

Zilliz Cloud に AWS S3 へのアクセス権を付与するために、IAM ポリシーを作成します。このポリシーには、Zilliz Cloud と S3 バケット間でのバックアップファイル転送を実現するための特定のアクションとリソースを含める必要があります。

簡単にするため、JSON エディターを使用してポリシーを作成します。

1

IAM コンソールで、ポリシー > Create policy を選択します。

2

ポリシーエディター セクションで、JSON オプションを選択します。

3

Zilliz Cloud から提供された JSON ポリシードキュメントをポリシーエディターにコピー&ペーストします。次に、Next をクリックします。

以下は JSON ポリシードキュメントのサンプルです。統合に合わせた正確なポリシーについては、Zilliz Cloud コンソールの Create IAM Policy ステップを参照してください。

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Statement1",
"Effect": "Allow",
"Action": [
"s3:GetObject",
"s3:PutObject",
"s3:ListBucket",
"s3:GetBucketLocation"
],
"Resource": [
"arn:aws:s3:::<bucket>",
"arn:aws:s3:::<bucket>/*"
]
}
]
}

ただし、AWS KMS を使用してバケットのサーバー側暗号化を有効にしている場合は、kms:Generateデータキー アクションを許可するために別の IAM ポリシーを追加する必要があります。この場合、以下の JSON ポリシーを使用してください。

{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "Statement1",
"Effect": "Allow",
"Action": [
"s3:GetObject",
"s3:PutObject",
"s3:ListBucket",
"s3:GetBucketLocation"
],
"Resource": [
"arn:aws:s3:::<bucket>",
"arn:aws:s3:::<bucket>/*"
]
},
{
"Sid": "AllowKMSGenerateDataKey",
"Effect": "Allow",
"Action": [
"kms:GenerateDataKey"
],
"Resource": "arn:aws:kms:<region>:<account_id>:key/<key_id>"
}
]
}
📘Notes
  • <bucket> は、実際の S3 バケット名に置き換える必要があります。

  • <region><account_id>、および <key_id> は、実際の値に置き換える必要があります。詳細については、AWS ドキュメントの キー identifiers を参照してください。

4

Review and create ページで、作成するポリシーの ポリシー名(例: zilliz-policy-for-integration-0819)と Description(オプション)を入力し、Permissions defined in this policy を確認します。ポリシー名を覚えておいてください。今後の手順で必要になります。

5

Create policy を選択して、新しいポリシーを保存します。完了したら、ステップ 4 に進みます。

ステップ 4: IAM ロールの作成

AWS コンソールで IAM ロールを作成する前に、Zilliz Cloud コンソールで以下を実行してください。

1

Zilliz Cloud コンソールで、Next をクリックして Create IAM ロール ステップに進みます。

2

Select trusted entity で、JSON コンテンツをコピーし、IAM コンソール に移動します。

これが完了したら、以下を実行して IAM ロールを作成します。

1

IAM コンソール で、ロールs > Create role を選択します。

2

カスタム信頼ポリシー ロールタイプを選択します。

3

カスタム信頼ポリシー セクションで、ロール用のカスタム信頼ポリシーをコピーして貼り付けます。次に、Next をクリックします。

以下はサンプルの JSON 信頼ポリシーです。統合に合わせた正確な信頼ポリシーについては、Zilliz Cloud コンソールの Create IAM ロール ステップを参照してください。

{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": "sts:AssumeRole",
"Principal": {
"AWS": "965570967084"
},
"Condition": {
"StringEquals": {
"sts:ExternalId": "my-external-id"
}
}
}
]
}
📘Notes

965570967084 および my-external-id は、Zilliz Cloud コンソールの Create IAM ロール ステップに表示される実際の AWS アカウント ID と外部 ID に置き換える必要があります。

4

Add permissions ステップの 権限ポリシー で、ステップ 3 で作成したポリシーを検索して選択し、権限を追加します。次に、Next をクリックします。

5

名前を付けて確認し、作成 ステップで、ロール名(例: zilliz-integration-role-0819)を入力し、設定を確認します。次に、Create role をクリックします。

6

作成したロールの詳細ページに移動し、ロールに対応する ARN をコピーします。これは ステップ 5 で Zilliz Cloud コンソールで必要になります。

ステップ 5: 統合の検証と追加

1

Zilliz Cloud コンソールCreate IAM ロール ステップで、前のステップで IAM コンソールからコピーした ARN を貼り付けます。

2

次に、統合の検証 をクリックして、S3 バケットと IAM ロールの設定を確認します。

3

ステータスが 成功 に変わると、統合が機能します。次に、Add をクリックします。

これで、この統合を使用してバックアップファイルをエクスポートしたり、監査ログを Amazon S3 バケットに転送したりできます。詳細については、Export Backup Files または 監査ログging を参照してください。

統合の管理

統合が追加されたら、必要に応じてその詳細を表示したり、統合を削除したりできます。

YODhb5leToWLsjxGRrpcyuZNnPb

統合IDの取得

RESTful API を使用して、Zilliz Cloud と統合された AWS S3 バケットのいずれかにバックアップファイルをエクスポートする必要がある場合は、View Details をクリックして統合の詳細を表示し、その統合IDをコピーします。

トラブルシューティング

統合プロセス中に問題が発生した場合、以下に一般的なエラーメッセージとその解決策を示します。

バケットリージョンの不一致

説明: S3 バケットのリージョンが Zilliz Cloud クラスターのリージョンと一致しない場合、以下の例のようなエラーが発生します。

"bucket region not match, want[us-west-1] got[us-west-2]"

ソリューション:

  • S3 バケットが配置されている AWS リージョンが、Zilliz Cloud クラスターのリージョンと一致していることを確認してください。

  • 必要に応じて、正しいリージョンに新しいバケットを作成するか、クラスターのリージョンをバケットのリージョンに合わせて調整してください。

バケット not found

説明: このエラーは、指定された S3 バケットが存在しないか、バケット名が正しくない場合に発生します。

check bucket failed: get bucket location: operation error S3: GetBucketLocation, https response error StatusCode: 404, RequestID: ..., HostID: ..., api error NoSuchBucket: The specified bucket does not exis

ソリューション:

  • Zilliz Cloud コンソールと AWS S3 コンソールの両方でバケット名を再確認してください。

  • バケットが存在し、その名前が Zilliz Cloud の設定に正しく入力されていることを確認してください。

Access denied for bucket location

説明: このエラーは、IAM ロールに S3 バケットの場所へアクセスするために必要な権限がない場合に発生します。

check bucket failed: get bucket location: operation error S3: GetBucketLocation, https response error StatusCode: 403 ...

ソリューション:

  • Zilliz Cloud によって使用されているロールにアタッチされた IAM ポリシーを確認します。

  • ポリシーに、s3:GetObjects3:PutObjects3:Listバケット などの他の必要な権限に加えて、s3:GetバケットLocation 権限が含まれていることを確認します。

ロールの引き受け失敗

説明: このエラーは、ロール ARN、外部 ID、またはトラストポリシーが正しくないことが原因で IAM ロールの引き受けに問題が発生した場合に発生します。

try assume role from[zilliz-role] to [arn:aws:iam::041623484421:role/testoss121703] with externalId[zilliz-external-1umVCIK7q96kzDE] failed

ソリューション:

  • Zilliz Cloud コンソールのロール ARN と外部 ID が、IAM 信頼ポリシーの対応する値と一致していることを確認します。

  • IAM ロールの信頼ポリシーで、Zilliz Cloud がロールを引き受けることを許可していることを確認します。