IVdsVolumePlex::Repair 方法 (vds.h)

[从 Windows 8 和 Windows Server 2012 开始,虚拟磁盘服务 COM 接口由 Windows 存储管理 API 取代。]

通过将错误成员移动到良好的磁盘来修复容错卷丛。

语法

HRESULT Repair(
  [in]  VDS_INPUT_DISK *pInputDiskArray,
  [in]  LONG           lNumberOfDisks,
  [out] IVdsAsync      **ppAsync
);

参数

[in] pInputDiskArray

指向 VDS_INPUT_DISK 结构数组的指针,每个磁盘对应一个结构。

注意 仅包括此结构的必需成员 (diskIdullSize) 。
 
Windows Server 2003: 只有使用奇偶校验 (RAID-5) 条带化的卷才能使用此方法进行修复,并且一次只能将一个新磁盘传递给此方法。

[in] lNumberOfDisks

卷中的磁盘总数。

[out] ppAsync

VDS 在返回时初始化的 IVdsAsync 接口指针的地址。 调用方必须释放接口。 使用此指针可以取消、等待或查询操作的状态。

如果对此方法调用 IVdsAsync::Wait 并返回成功的 HRESULT 值,则必须通过在每个接口指针上调用 IUnknown::Release 方法释放VDS_ASYNC_OUTPUT结构中返回的接口。 但是,如果 Wait 返回失败的 HRESULT 值,或者如果 WaitpHrResult 参数收到失败的 HRESULT 值,则VDS_ASYNC_OUTPUT结构中的接口指针为 NULL,无需释放。 可以使用 Winerror.h 中定义的 SUCCEEDEDFAILED 宏测试成功或失败 HRESULT 值。

返回值

此方法可以返回标准 HRESULT 值,例如E_INVALIDARG或E_OUTOFMEMORY,以及 特定于 VDS 的返回值。 它还可以使用 HRESULT_FROM_WIN32 宏返回转换的系统错误代码。 错误可能源自 VDS 本身或正在使用的基础 VDS 提供程序 。 可能的返回值包括以下内容。

返回代码/值 说明
S_OK
修复已成功完成。
E_NOTIMPL
调用方尝试修复基本卷的 plex,该卷始终正常运行,永远不需要修复。
VDS_E_REPAIR_VOLUMESTATE
0x80042460L
plex 或卷不可访问。 此外,当 plex 的状态不是下列之一时,可能会返回此错误:失败的冗余、失败的冗余或失败的冗余失败。
VDS_E_DISK_IN_USE_BY_VOLUME
0x8004244CL
卷已在使用磁盘的一个或多个盘区。
VDS_E_VOLUME_INCOMPLETE
0x80042432L
卷缺少一个或多个成员,或者以某种方式不完整。

要求

   
最低受支持的客户端 Windows Vista [仅限桌面应用]
最低受支持的服务器 Windows Server 2003 [仅限桌面应用]
目标平台 Windows
标头 vds.h
Library Uuid.lib

请参阅

IVdsAsync

IVdsAsync::Wait

IVdsVolumePlex

VDS_ASYNC_OUTPUT

VDS_INPUT_DISK