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 对象。