IVdsHwProviderStoragePools::CreateLunInStoragePool 方法 (vdshwprv.h)
[從Windows 8和Windows Server 2012開始,虛擬磁碟服務COM 介面會由Windows 儲存體管理 API取代。
在 存放集區中建立 LUN。
語法
HRESULT CreateLunInStoragePool(
[in] VDS_LUN_TYPE type,
[in] ULONGLONG ullSizeInBytes,
[in] VDS_OBJECT_ID StoragePoolId,
[in] LPWSTR pwszUnmaskingList,
[in] VDS_HINTS2 *pHints2,
[out] IVdsAsync **ppAsync
);
參數
[in] type
VDS_LUN_TYPE列舉值,指定要建立的 LUN 類型。 新的 LUN 可以是自動損壞類型或特定的 RAID 類型,但不能同時是兩者。 如果呼叫端指定自動magic 類型,則應在 pHints2 參數中指定一或多個 automagic 提示。
您可以在ppAsync參數傳回的介面指標上呼叫IVdsAsync::Wait方法,以擷取新LUN 物件的介面指標。 Wait傳回的VDS_ASYNC_OUTPUT結構包含cl.pLunUnk成員中的 LUN 物件介面指標。
[in] ullSizeInBytes
新 LUN 的大小,以位元組為單位。 提供者可以將大小向上或向下四捨五入,以符合對齊需求或其他限制。 (在大部分情況下,提供者會四捨五入,以確保在罕見的例外狀況下,LUN 至少會和要求的大小一樣大。)
建立 LUN 之後,呼叫端可以藉由呼叫 IVdsLun::GetProperties 方法來判斷 LUN 的實際大小。
[in] StoragePoolId
VDS_OBJECT_ID值,識別要建立 LUN 的存放集區。 這個參數是必要的,而且不能GUID_Null。
[in] pwszUnmaskingList
清單,指定要授與 LUN 存取權的電腦。 此清單是以分號分隔、 以 Null結尾、人類可讀取的字串。
如果值為 「 」,則所有已連結 HBA 埠的電腦都會被授與 LUN 的存取權。 如果值為 「」,則不會將 LUN 的存取權授與任何電腦。
如果指定 「*」 或 「」,則無法指定其他值。
對於光纖通道網路和序列連結的 SCSI (SAS) 網路,每個專案都是 64 位的萬維名稱 (WWN) ,其中 LUN 未遮罩的每個埠,格式為十六進位字串, (16 個字元長) ,最重要的位元組優先。 例如,01:23:45:67:89:AB:CD:EF 的 WWN 位址會以 「0123456789ABCDEF」 表示。 如需詳細資訊,請參閱 光纖通道 和 SAS的 T10 規格。
對於 iSCSI 網路,每個專案都是 iSCSI 限定名稱, (IQN) LUN 解除遮罩的每個啟動器。 未遮罩至特定啟動器的 LUN 會被視為與該啟動器相關聯。
[in] pHints2
VDS_HINTS2結構的指標,指定要用於建立 LUN 的提示。 不需要提供者,即可將提示套用至 LUN。 VDS_HINTS2結構中指定的提示只是提供者的要求。
建立 LUN 之後,呼叫端可以藉由呼叫 IVdsLun2::QueryHints2 方法來判斷提供者所套用的提示。
如果 類型 參數指定非自動損壞類型,此參數應該是 Null。
[out] ppAsync
在成功完成時 ,IVdsAsync 介面的指標會收到 IVdsAsync 介面來監視和控制這項作業。 呼叫端必須在使用介面完成時釋放收到的介面。 如果在介面上呼叫IVdsAsync::Wait方法,並傳回成功的 HRESULT 值,則必須在每個介面指標上呼叫IUnknown::Release方法,以釋放VDS_ASYNC_OUTPUT結構中傳回的介面。 不過,如果Wait傳回失敗 HRESULT 值,或Wait的pHrResult參數收到失敗 HRESULT 值,則VDS_ASYNC_OUTPUT結構中的介面指標為Null且不需要釋放。 您可以使用 Winerror.h 中定義的 SUCCEEDED 和 FAILED 宏來測試成功或失敗 HRESULT 值。
傳回值
這個方法可以傳回標準 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 VDS 特定的傳回值。 它也可以使用HRESULT_FROM_WIN32宏傳回已轉換的系統錯誤碼。 錯誤可能源自 VDS 本身,或來自正在使用的基礎 VDS 提供者 。 可能的傳回值包括下列專案。
傳回碼 | 描述 |
---|---|
|
已成功完成命令。 |
備註
藉由為 類型和pHints2 參數選擇適當的值,呼叫端可以指定 LUN 的完全、部分或最小屬性。 提供者可以根據pHints2參數所指向之VDS_HINTS2結構中指定的自動magic 提示,自動包含未指定的屬性。
實作者的注意事項:提供者必須傳回ppAsync參數中的IVdsAsync介面指標,即使呼叫這個方法未起始非同步作業也一樣。
pwszUnmaskingList參數中的 WWN 和 IQN 清單可能包含重複的名稱。 提供者必須負責驗證清單中的所有名稱,並視需要移除重複專案。
為了回應 CreateLunInStoragePool 方法,以及在將新 LUN 取消遮罩至任何主機之前,提供者應該以零填滿第一個和最後 MB,讓 LUN 未初始化。
E_INVALIDARG與VDS_E_NOT_SUPPORTED傳回值之間有細微差異。 提供者不預期會實作 VDS API 可以呈現給用戶端的每個功能。 例如, CreateLunInStoragePool 方法會公開建立許多不同類型的 LUN (的能力,例如簡單、鏡像、等量和同位) 。 不過,不需要提供者才能支援所有類型的 LUN。 如果呼叫端為不是有效VDS_LUN_TYPE列舉值的型別參數指定值,提供者應該會傳回E_INVALIDARG。 如果呼叫端指定提供者不支援的有效 型別 值,提供者應該傳回VDS_E_NOT_SUPPORTED。
規格需求
最低支援的用戶端 | Windows 7 [僅限傳統型應用程式] |
最低支援的伺服器 | Windows Server 2008 R2 [僅限桌面應用程式] |
目標平臺 | Windows |
標頭 | vdshwprv.h |
程式庫 | Uuid.lib |