API を使用して LUN をプロビジョニングする
Active IQ Unified Managerの一部として提供されるプロビジョニング API を使用して、Storage Virtual Machines (SVM) 上で LUN をプロビジョニングできます。このプロビジョニング ワークフローでは、LUNを作成する前にSVM、パフォーマンス サービス レベル、およびストレージ効率化ポリシーのキーを取得する手順について詳しく説明します。
次の図は、LUNのプロビジョニング ワークフローの手順を示しています。

|
このワークフローでは、 ONTAPクラスタが Unified Manager に追加され、クラスタ キーが取得されていることを前提としています。また、SVMがすでにクラスタに作成されていることも前提としています。 |
-
「クラスタ上の SVM の検証」ワークフロー トピックの説明に従って、LUN を作成する SVM の SVM キーを取得します。
-
次のAPIを実行し、応答からパフォーマンス サービス レベルのキーを取得します。
カテゴリ HTTP動詞 パス storage-provider
GET
/storage-provider/performance-service-levels
システム定義のパフォーマンスサービスレベルの詳細は、
system_defined`入力パラメータ `true
。出力から、LUNに適用するパフォーマンス サービス レベルのキーを取得します。 -
必要に応じて、次のAPIを実行し、応答からLUNに適用するストレージ効率化ポリシーのキーを取得します。
カテゴリ HTTP動詞 パス storage-provider
GET
/storage-provider/storage-efficiency-policies
-
作成するLUNターゲットへのアクセスを付与するイニシエータ グループ(igroup)が作成されているかどうかを確認します。
カテゴリ HTTP動詞 パス datacenter
GET
/datacenter/protocols/san/igroups
/datacenter/protocols/san/igroups/{key}
igroupがアクセス権を有するSVMをパラメータ値として入力する必要があります。また、特定のigroupを照会する場合は、入力パラメータとしてigroup名(キー)を指定します。
-
アクセスを付与するigroupが出力に見つかった場合は、そのキーを取得します。見つからない場合はigroupを作成します。
カテゴリ HTTP動詞 パス datacenter
POST
/datacenter/protocols/san/igroups
作成するigroupの詳細を入力パラメータとして指定する必要があります。これは同期呼び出しであり、igroupの作成を出力で確認できます。エラーが発生した場合はエラー メッセージが表示されるため、トラブルシューティングしてAPIを再実行します。
-
LUNを作成
カテゴリ HTTP動詞 パス storage-provider
POST
/storage-provider/luns
LUNを作成する場合は、取得した値を必須パラメータとして指定する必要があります。
ストレージ効率化ポリシーは、LUNの作成ではオプションのパラメータです。
サンプル cURL
作成するLUNのすべての詳細を入力パラメータとして指定する必要があります。
JSON出力にジョブ オブジェクト キーが表示され、作成したLUNの検証に使用できます。
-
ジョブの照会で返されたジョブ オブジェクト キーを使用して、LUNの作成を確認します。
カテゴリ HTTP動詞 パス management-server
GET
/management-server/jobs/{key}
応答の末尾に、作成されたLUNのキーが表示されます。
-
返されたキーを指定して次のAPIを実行し、LUNの作成を確認します。
カテゴリ HTTP動詞 パス storage-provider
GET
/storage-provider/luns/{key}
サンプルJSON出力
POSTメソッドの
/storage-provider/luns`各関数に必要なすべての API を内部的に呼び出し、オブジェクトを作成します。例えば、 `/storage-provider/performance-service-levels/
LUN にパフォーマンス サービス レベルを割り当てるための API。== LUNの作成またはマッピングの失敗に関するトラブルシューティング手順
このワークフローを完了したあとも引き続きLUNの作成に失敗することがあります。LUNの作成に成功しても、LUNを作成したノードにSAN LIFまたはアクセス エンドポイントがないためにigroupとのLUNマッピングが失敗することがあります。エラーが発生した場合は、次のメッセージが表示されます。
The nodes <node_name> and <partner_node_name> have no LIFs configured with the iSCSI or FCP protocol for Vserver <server_name>. Use the access-endpoints API to create a LIF for the LUN.
このエラーを回避するには、次のトラブルシューティング手順を実行します。
-
LUNを作成しようとしたSVMに、ISCSI/FCPプロトコルをサポートするアクセス エンドポイントを作成します。
カテゴリ HTTP動詞 パス storage-provider
POST
/storage-provider/access-endpoints
サンプル cURL
作成するアクセス エンドポイントの詳細を、入力パラメータとして指定する必要があります。
入力パラメータに、LUNのホーム ノードを示すaddressと、ホーム ノードのパートナー ノードを示すha_addressを追加したことを確認します。この処理を実行すると、ホーム ノードとパートナー ノードの両方にアクセス エンドポイントが作成されます。
-
JSON出力で返されたジョブ オブジェクト キーを使用してジョブを照会し、SVMにアクセス エンドポイントを追加するジョブが正常に実行されたこと、およびSVMでiSCSI/FCPサービスが有効になっていることを確認します。
カテゴリ HTTP動詞 パス management-server
GET
/management-server/jobs/{key}
サンプルJSON出力
出力の末尾に、作成されたアクセス エンドポイントのキーが表示されます。次の出力では、「name": "accessEndpointKey" の値は、キーが 9c964258-14ef-11ea-95e2-00a098e32c28 である LUN のホーム ノードに作成されたアクセス エンドポイントを示しています。 "name": "accessEndpointHAKey" 値は、ホーム ノードのパートナー ノード上に作成されたアクセス エンドポイントを示します。そのキーは 9d347006-14ef-11ea-8760-00a098e3215f です。
-
LUNを変更してigroupマッピングを更新します。ワークフローの変更の詳細については、「
ストレージ ワークロードの変更
」を参照してください。カテゴリ HTTP動詞 パス storage-provider
PATCH
/storage-provider/lun/{key}
入力で、LUNマッピングの更新に使用するigroupキーと、LUNキーを指定します。
サンプル cURL
JSON出力にジョブ オブジェクト キーが表示され、マッピングが成功したかどうかの検証に使用できます。
-
LUNキーを指定して照会することで、LUNマッピングを確認します。
カテゴリ HTTP動詞 パス storage-provider
GET
/storage-provider/luns/{key}
サンプルJSON出力
出力から、LUNのプロビジョニング時に使用されたigroup(キーd19ec2fa-fec7-11e8-b23d-00a098e32c28)にLUNが正常にマッピングされていることがわかります。