外部ボリューム
外部ボリュームは、お客様のクラウドオブジェクトストレージ(AWS S3 や Google Cloud Storage など)内のバケットまたはパスへの読み取り専用の参照であり、Zilliz Cloud がデータをコピーまたは移動することなく、その場でデータにアクセスできるようにします。
このページでは、Web コンソールと SDK を使用して外部ボリュームを作成および削除する方法について説明します。
考慮事項
-
ボリュームは AWS と Google Cloud でのみ利用可能です。Azure の場合は、サポートにお問い合わせ ください。
-
ボリュームはプロジェクトのクラウドプロバイダーとリージョンに制限されます。例えば、プロジェクトが AWS us-west-2 にある場合、AWS us-west-2 のボリュームのみを作成できます。
-
ボリュームをクラスターで使用するには、クラスターがボリュームと同じクラウドプロバイダーおよびリージョンに存在する必要があります。
-
ボリュームを作成および管理するには、プロジェクト管理者 である必要があります。
-
ボリュームが作成されると、その設定を編集することはできません。ボリュームの設定を変更したい場合は、必要な設定で新しいボリュームを作成してください。
-
外部ボリュームでは、データはお客様のバケットに残ります。そのため、データファイルは外部ボリュームではなく、お客様のクラウドオブジェクトストレージで管理する必要があります。
-
各組織は最大 100 個の外部ボリューム を作成できます。
開始前の準備
外部ボリュームを作成する前に、AWS S3 バケット または Google GCS バケット を統合する必要があります。ストレージ統合は、作成する外部ボリュームと同じクラウドプロバイダーおよびリージョンに存在する必要があることに注意してください。
外部ボリュームの作成
-
SDK を使用する場合
- Python
- Java
- cURL
# Initiate a volume managerfrom pymilvus.bulk_writer.volume_manager import VolumeManagervolume_manager = VolumeManager(cloud_endpoint="https://api.cloud.zilliz.com",api_key="YOUR_API_KEY")# Create a volumevolume_manager.create_volume(project_id="proj-xxxxxxxxxxxxxxxxxxxxxxx",region_id="aws-us-west-2",volume_name="external_volume",volume_type="EXTERNAL",storage_integration_id="integ-xxxx",path="data/",)print(f"\nVolume external_volume created")# Volume external_volume created// Initiate a volume managerimport io.milvus.bulkwriter.VolumeManager;import io.milvus.bulkwriter.VolumeManagerParam;VolumeManagerParam volumeManagerParam = VolumeManagerParam.newBuilder().withCloudEndpoint("https://api.cloud.zilliz.com").withApiKey("YOUR_API_KEY").build();VolumeManager volumeManager = new VolumeManager(volumeManagerParam);// Create a EXTERNAL volumeimport io.milvus.bulkwriter.request.volume.CreateVolumeRequest;CreateVolumeRequest request = CreateVolumeRequest.builder().projectId("proj-xxxxxxxxxxxxxxxxxxxxxxx").regionId("aws-us-west-2").volumeName("external_volume").type("EXTERNAL").storageIntegrationId("integ-xxxx").path("data/").build();volumeManager.createVolume(request);System.out.printf("\nVolume %s created%n", "external_volume");// Volume external_volume createdexport BASE_URL="https://api.cloud.zilliz.com"export TOKEN="YOUR_API_KEY"curl --request POST \--url "${BASE_URL}/v2/volumes/create" \--header "Authorization: Bearer ${TOKEN}" \--header "Content-Type: application/json" \-d '{"projectId": "proj-xxxx","regionId": "aws-us-west-2","volumeName": "external_volume","type": "EXTERNAL","storageIntegrationId": "integ-xxxx","path": "/data/"}'# {# "code": 0,# "data": {# "volumeName": "external_volume"# }# }次の表にパラメーターを説明します。
パラメーター
説明
projectIdボリュームを作成するプロジェクトの ID。
regionId作成するボリュームのリージョンは、データのインポートまたは移行を予定しているターゲットクラスターのクラウドプロバイダーとリージョンと一致している必要があります。
volumeName作成するボリュームの名前は、組織全体で一意である必要があり、64 文字以内で、文字またはアンダースコアで始まり、文字、数字、ハイフン、アンダースコアのみを含む必要があります。
type外部ボリュームを作成するには、このパラメーターを
EXTERNALに設定します。デフォルトはMANAGEDです。storageIntegrationId参照するストレージ統合の ID。
type=EXTERNALの場合に必須です。選択するストレージ統合は、作成する外部ボリュームと同じ組織およびリージョンに属している必要があります。pathストレージパス。
type=EXTERNALの場合に必須です。 -
ウェブコンソール経由
1左側のナビゲーションで、ボリュームs をクリックします。
2ボリュームページで、+ ボリューム をクリックします。
3ボリュームの設定を行います。
外部ボリュームの作成時に使用する各パラメーターの説明を次の表に示します。
パラメーター
説明
Name
ボリューム名は、組織全体で一意である必要があり、64 文字以内で、文字またはアンダースコアで始まり、文字、数字、ハイフン、アンダースコアのみを含む必要があります。
Description
このパラメーターはオプションです。
ボリューム Type
ボリュームタイプとして「External」を選択します。
クラウドプロバイダーとリージョン
ボリュームのクラウドプロバイダーとリージョンは、データのインポートまたは移行を予定しているターゲットクラスターのクラウドプロバイダーとリージョンと一致している必要があります。
ストレージ統合とパス
ストレージ統合(AWS S3 バケット、Google GCS バケット、または Azure BLOB コンテナー)は、クラウドストレージのアクセス設定をカプセル化した認証情報オブジェクトです。
パスは、データが配置されている場所へのポインターです。(例:
folder/)4Create をクリックします。
List external volumes
プロジェクト内のすべての既存ボリュームを表示できます。
-
SDK 経由
- Python
- Java
- Shell
# Initiate a volume managerfrom pymilvus.bulk_writer.volume_manager import VolumeManagervolume_manager = VolumeManager(cloud_endpoint="https://api.cloud.zilliz.com",api_key="YOUR_API_KEY")# View volumesvolume_list = volume_manager.list_volumes(project_id="proj-xxxxxxxxxxxxxxxxxxxxxxx",current_page=1,page_size=10)print(f"\nlistVolumes results: \n", volume_list.json()['data'])# listVolumes results:## {# "count": 1,# "currentPage": 1,# "pageSize": 10,# "volumes": [# {# "volumeName": "external_volume"# "type":"EXTERNAL"# }# ]# }// Initiate a volume managerimport io.milvus.bulkwriter.VolumeManager;import io.milvus.bulkwriter.VolumeManagerParam;VolumeManagerParam volumeManagerParam = VolumeManagerParam.newBuilder().withCloudEndpoint("https://api.cloud.zilliz.com").withApiKey("YOUR_API_KEY").build();VolumeManager volumeManager = new VolumeManager(volumeManagerParam);// View volumesimport com.google.gson.Gson;import io.milvus.bulkwriter.request.volume.ListVolumesRequest;import io.milvus.bulkwriter.response.volume.ListVolumesResponse;ListVolumesRequest request = ListVolumesRequest.builder().projectId("proj-xxxxxxxxxxxxxxxxxxxxxxx").currentPage(1).pageSize(10).build();ListVolumesResponse listVolumesResponse = volumeManager.listVolumes(request);System.out.println("\nlistVolumes results: " + new Gson().toJson(listVolumesResponse));// listVolumes results://// {// "count": 1,// "currentPage": 1,// "pageSize": 10,// "volumes": [// {// "volumeName": "external_volume",// "type":"EXTERNAL"// }// ]// }export BASE_URL="https://api.cloud.zilliz.com"export TOKEN="YOUR_API_KEY"curl --request GET \--url "${BASE_URL}/v2/volumes?projectId=proj-xxxxxxxxxxxxxxxxx" \--header "Authorization: Bearer ${TOKEN}" \--header "Content-Type: application/json"# {# "code": 0,# "data": {# "volumes": [# {# "volumeName": "external_volume",# "type": "EXTERNAL"# }# ],# "count": 1,# "currentPage": 1,# "pageSize": 10# }#} -
ウェブコンソール経由

Describe external volume
特定のボリュームの詳細を確認できます。
-
Via SDKs
- Python
- Java
- cURL
# Initiate a volume managerfrom pymilvus.bulk_writer.volume_manager import VolumeManagervolume_manager = VolumeManager(cloud_endpoint="https://api.cloud.zilliz.com",api_key="YOUR_API_KEY")# View volumesvolume_list = volume_manager.describe_volume(volume_name="external_volume")print(f"\ndescVolume results: \n", volume_list.json()['data'])# descVolume results:## {# "volumeName": "external_volume",# "type": "EXTERNAL",# "regionId": "aws-us-west-2",# "storageIntegrationId": "integ-xxxx",# "path": "data/",# "status": "RUNNING",# "createTime": "2024-04-15T12:00:00Z",# }// Initiate a volume managerimport io.milvus.bulkwriter.VolumeManager;import io.milvus.bulkwriter.VolumeManagerParam;VolumeManagerParam volumeManagerParam = VolumeManagerParam.newBuilder().withCloudEndpoint("https://api.cloud.zilliz.com").withApiKey("YOUR_API_KEY").build();VolumeManager volumeManager = new VolumeManager(volumeManagerParam);// View volumesimport com.google.gson.Gson;import io.milvus.bulkwriter.request.volume.DescribeVolumeRequest;import io.milvus.bulkwriter.response.volume.VolumeInfo;DescribeVolumeRequest request = DescribeVolumeRequest.builder().volumeName("descVolume").build();VolumeInfo volumeInfo = volumeManager.describeVolume(request);System.out.println("\ndescVolume results: " + new Gson().toJson(volumeInfo));// descVolume results:////{// "volumeName": "volume-22222lentitude",// "type": "EXTERNAL",// "regionId": "aws-us-west-2",// "storageIntegrationId": "integ-lir5xfbcgrkla6fjc39w15qjk",// "path": "",// "status": "RUNNING",// "createTime": "2026-04-27T15:40:53Z"//}export BASE_URL="https://api.cloud.zilliz.com"export TOKEN="YOUR_API_KEY"curl --request GET \--url "${BASE_URL}/v2/volumes/${VOLUME_NAME}" \--header "Authorization: Bearer ${TOKEN}" \--header "Content-Type: application/json"# {# "code": 0,# "data": {# "volumeName": "external_volume",# "type": "EXTERNAL",# "regionId": "aws-us-west-2",# "storageIntegrationId": "si-xxxx",# "path": "data/",# "status": "RUNNING",# "createTime": "2024-04-15T12:00:00Z"# }#} -
ウェブコンソール経由

外部ボリュームの削除
不要になった場合は、いつでも外部ボリュームを削除できます。
外部ボリュームの削除は、Zilliz Cloud からボリュームのメタデータのみを削除します。データはクラウドオブジェクトストレージにそのまま残ります。
-
Via SDKs
- Python
- Java
- cURL
# Initiate a volume managerfrom pymilvus.bulk_writer.volume_manager import VolumeManagervolume_manager = VolumeManager(cloud_endpoint="https://api.cloud.zilliz.com",api_key="YOUR_API_KEY")# Delete a volumevolume_manager.delete_volume(volume_name="external_volume")print(f"\nVolume external_volume deleted")# Volume external_volume deleted// Initiate a volume managerimport io.milvus.bulkwriter.VolumeManager;import io.milvus.bulkwriter.VolumeManagerParam;VolumeManagerParam volumeManagerParam = VolumeManagerParam.newBuilder().withCloudEndpoint("https://api.cloud.zilliz.com").withApiKey("YOUR_API_KEY").build();VolumeManager volumeManager = new VolumeManager(volumeManagerParam);// Delete a volumeimport io.milvus.bulkwriter.request.volume.DeleteVolumeRequest;DeleteVolumeRequest request = DeleteVolumeRequest.builder().volumeName("external_volume").build();volumeManager.deleteVolume(request);System.out.printf("\nVolume %s deleted%n", "external_volume");// Volume external_volume deletedexport BASE_URL="https://api.cloud.zilliz.com"export TOKEN="YOUR_API_KEY"export VOLUME_NAME="external_volume"curl --request DELETE \--url "${BASE_URL}/v2/volumes/${VOLUME_NAME}" \--header "Authorization: Bearer ${TOKEN}" \--header "Content-Type: application/json"# {# "code": 0,# "data": {# "volumeName": "external_volume"# }# } -
ウェブコンソール経由
1左側のナビゲーションで ボリュームs をクリックします。
2Actions 列の ... をクリックし、Delete を選択します。
3ボリューム名を入力し、Delete をクリックします。
請求
外部ボリュームの作成と使用には、Zilliz Cloud の料金は発生しません。お支払い方法の登録は不要です。
ただし、インポートまたは移行時に Zilliz Cloud がバケットから読み取る際、クラウドプロバイダーがデータリクエスト料金を請求する場合があります。詳細については、Amazon S3 Pricing または Google Cloud Storage Pricing を参照してください。
FAQs
請求書の未払いにより組織が凍結された場合、ボリュームはどうなりますか?
組織が凍結されると、管理対象のすべての ボリューム — 無料トライアルおよび従量課金制の両方 — およびそれらに保存されているすべてのファイルが削除され、復元することはできません。外部ボリュームも凍結され、新しい操作には使用できなくなりますが、お客様のバケット内のデータには影響しません。
ボリュームの使用を継続するには、まずすべての未払いの請求書を精算してください。
外部ボリュームと外部ストレージからの直接インポートの違いは何ですか?
どちらもお客様の S3 または GCS バケットからデータをインポートできます。主な違いは以下の通りです。
-
外部ボリュームでは、AWS S3 bucket、Google Cloud Storage bucket、または Microsoft Azure blob storage container を Zilliz Cloud と統合して、認証情報の管理を行う必要があります。認証情報は一度設定すれば、複数のボリュームや操作で再利用できます。データエンジニアはクラウドストレージのキーに直接アクセスする必要はありません。
-
直接の external storage import では、各インポートリクエストごとに認証情報(アクセスキー、シークレットキー)をインラインで提供する必要があります。これは一度限りのインポートにはシンプルですが、認証情報の分離や再利用性は提供しません。
外部ボリューム作成後に、ストレージ統合やパスを変更できますか?
~しない。外部ボリューム作成後、ストレージ統合とパスは変更できません。別のストレージ統合やパスを使用する場合は、新しい外部ボリュームを作成してください。
アクティブなジョブや外部コレクションから参照されている外部ボリュームを削除できますか?
~しない。ダウンストリームの外部コレクションまたはアクティブなジョブがボリュームを参照している場合、削除はブロックされます。
外部ボリュームの使用時にデータ転送料金は請求されますか?
~しない。外部ボリュームは、クラスターと同じクラウドプロバイダーおよびリージョンに存在する必要があります。すべてのデータアクセスは同一リージョン内で発生するため、Zilliz Cloud ではリージョン間データ転送料金は発生しません。
ボリュームのステータスはどのような意味ですか?
以下の表に、考えられるボリュームのステータスを示します。
Status | Description |
|---|---|
Available | The volume is active and usable. |
Frozen | The organization is frozen due to overdue invoices. The volume cannot be used for new operations. Please pay your bill to continue using volumes. |
Error | The storage integration validation failed. Check the configuration and retry. |