New-SCVMCheckpoint
为 VMM 托管的主机上部署的虚拟机创建检查点。
语法
New-SCVMCheckpoint
[-VM] <VM>
[-VMMServer <ServerConnection>]
[-Description <String>]
[-Name <String>]
[-RunAsynchronously]
[-PROTipID <Guid>]
[-JobVariable <String>]
[-WhatIf]
[-Confirm]
[-OnBehalfOfUser <String>]
[-OnBehalfOfUserRole <UserRole>]
[<CommonParameters>]
说明
New-SCVMCheckpoint cmdlet 为由 Virtual Machine Manager 托管的主机上部署的虚拟机创建检查点, (VMM) 。 可以使用检查点将虚拟机还原到先前的状态。
典型的用途是在将更新安装到操作系统或虚拟机上的应用程序之前创建检查点,这样,如果更新失败或对虚拟机产生负面影响,则可以使用 Restore-SCVMCheckpoint cmdlet 将虚拟机还原到其以前的状态。
对于部署在 Hyper-V 主机、VMware ESX 主机或 Citrix XenServer 主机上的虚拟机,VMM 会创建检查点而不停止虚拟机,因此不会中断服务。
重要的是,在将虚拟机还原到检查点之前,应该备份虚拟机上的数据文件。 在恢复虚拟机时,虚拟硬盘上的用户数据文件将恢复到先前的状态。
尽管检查点让您能够在进行系统或应用程序更新等更改之后将虚拟机还原到先前的状态,但检查点并不提供操作系统、应用程序或文件的永久备份。 检查点同虚拟机一起存储到主机上。 因此,如果主机发生故障,部署在该主机上的虚拟机的检查点也会丢失。
若要为虚拟机提供数据保护,可以使用卷影复制服务 (VSS) 。 可以使用备份应用程序(例如 Data Protection Manager (DPM) )将任何类型的主机上的虚拟机备份到外部存储。
您可以向自助服务用户授予创建和管理各自虚拟机的检查点的权限。
要了解详情,请键入 Get-Help Set-VMMUserRole -Detailed
。
示例
示例 1:为具有相同名称但驻留在不同的主机上的虚拟机创建虚拟机检查点
PS C:\> $Checkpoints = Get-SCVirtualMachine -Name "VM01" | New-SCVMCheckpoint
PS C:\> $Checkpoints
第一个命令获取名为 VM01 的虚拟机对象 (此示例假定多个主机包含名为 VM01 的虚拟机) ,为每个虚拟机对象创建一个检查点,然后将检查点对象存储在$Checkpoints对象数组中。
第二个命令显示有关存储在用户$Checkpoints中的每个检查点对象的信息。
示例 2:异步为虚拟机创建虚拟机检查点
PS C:\> Get-SCVirtualMachine -Name "VM02" | New-SCVMCheckpoint -RunAsynchronously -JobVariable "NewCheckpiontJob"
PS C:\> Write-Host $NewCheckpointJob
此示例以与示例 1 相同的方式创建检查点,但此命令使用 RunAsynchronously 参数立即返回命令 shell 的控制,并使用 JobVariable 参数跟踪作业进度并在 NewCheckpointJob 变量中存储进度记录。 使用 JobVariable 参数时,不使用美元符号 ($) 创建变量。
第二个命令显示$NewCheckpointJob的内容。
参数
-Confirm
提示你在运行 cmdlet 之前进行确认。
Type: | SwitchParameter |
Aliases: | cf |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Description
指定检查点的说明。
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-JobVariable
指定跟踪作业进度,并将其存储在此参数命名的变量中。
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Name
指定 VMM 对象的名称。
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-OnBehalfOfUser
指定用户的名称。 此 cmdlet 将代表用户设置为此参数指定的用户。
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-OnBehalfOfUserRole
指定用户角色。 若要获取用户角色,请使用 Get-SCUserRole cmdlet。 此 cmdlet 代表此参数指定的用户角色进行操作。
Type: | UserRole |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-PROTipID
指定触发此操作 (PRO 提示) 的性能和资源优化提示的 ID。 此参数允许审核 PRO 提示。
Type: | Guid |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-RunAsynchronously
指示作业以异步方式运行,以便控件立即返回到命令 shell。
Type: | SwitchParameter |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-VM
指定一个虚拟机对象。
Type: | VM |
Position: | 0 |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-VMMServer
指定VMM 服务器对象。
Type: | ServerConnection |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-WhatIf
显示在此 cmdlet 运行的情况下将会发生什么。 此 cmdlet 未运行。
Type: | SwitchParameter |
Aliases: | wi |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
输出
VMCheckpoint
此 cmdlet 返回 VMCheckpoint 对象。