Msvm_ImageManagementService 类的 CompactVirtualHardDisk 方法
压缩虚拟硬盘文件。 压缩是释放虚拟硬盘未使用部分的过程。 虚拟硬盘不会自动装载。 有关此方法的使用限制,请参阅说明。
语法
uint32 CompactVirtualHardDisk(
[in] string Path,
[in] uint16 Mode,
[out] CIM_ConcreteJob REF Job
);
参数
-
路径 [in]
-
类型: 字符串
一个指定合并文件位置的完全限定路径。
-
模式 [in]
-
类型: uint16
指定压缩操作的模式。 这必须是以下值之一。
-
完整 (0)
-
快速 (1)
-
retrim (2)
-
预压缩 (3)
-
预零 (4)
作业 [out]
类型: CIM_ConcreteJob
如果任务) 完成,对作业 (的引用可以为 Null 。
返回值
类型: uint32
此方法可以返回以下值之一。
-
已完成,无错误 (0)
-
方法参数已选中 - 作业已启动 (4096)
-
( 32768) 失败
-
拒绝访问 (32769)
-
不支持 (32770)
-
状态未知 (32771)
-
超时 (32772)
-
参数 (32773) 无效
-
系统正在使用 (32774)
-
此操作的无效状态 (32775)
-
数据类型 (32776) 不正确
-
系统 ( 32777) 不可用
-
内存不足 (32778)
-
(32779) 找不到文件
备注
只有以下类型的虚拟硬盘才能与此方法一起使用:
- 修复了 VHDX
- 动态 VHD
- 动态 VHDX
- 差异 VHD
- 差异 VHDX
UAC 筛选可能会限制对 Msvm_ImageManagementService 类的访问。 有关详细信息,请参阅 用户帐户控制和 WMI。
示例
以下 C# 示例压缩虚拟硬盘。 可以在 V2) (虚拟化示例的常用实用工具 中找到引用的实用工具。
public enum VirtualHardDiskCompactMode
{
Full = 0,
Quick = 1,
Retrim = 2,
Pretrimmed = 3,
Prezeroed = 4
}
public static void CompactVirtualHardDisk(string vhdPath, VirtualHardDiskCompactMode compactMode)
{
ManagementScope scope = new ManagementScope(@"root\virtualization\v2", null);
ManagementObject imageService = Utility.GetServiceObject(scope, "Msvm_ImageManagementService");
ManagementBaseObject inParams = imageService.GetMethodParameters("CompactVirtualHardDisk");
inParams["Path"] = vhdPath;
inParams["Mode"] = compactMode;
ManagementBaseObject outParams = imageService.InvokeMethod("CompactVirtualHardDisk", inParams, null);
if ((UInt32)outParams["ReturnValue"] == ReturnCode.Started)
{
if (Utility.JobCompleted(outParams, scope))
{
Console.WriteLine("{0} was compacted successfully.", inParams["Path"]);
}
else
{
Console.WriteLine("Unable to compact {0}", inParams["Path"]);
}
}
else
{
Console.WriteLine("Compact {0} returned error {1}", inParams["Path"], outParams["ReturnValue"]);
}
inParams.Dispose();
outParams.Dispose();
imageService.Dispose();
}
要求
要求 | 值 |
---|---|
最低受支持的客户端 |
Windows 8 [仅限桌面应用] |
最低受支持的服务器 |
Windows Server 2012 [仅限桌面应用] |
命名空间 |
Root\Virtualization\V2 |
MOF |
|
DLL |
|
另请参阅
反馈
https://aka.ms/ContentUserFeedback。
即将发布:在整个 2024 年,我们将逐步淘汰作为内容反馈机制的“GitHub 问题”,并将其取代为新的反馈系统。 有关详细信息,请参阅:提交和查看相关反馈