在 VMware 中创建预准备映像计算机目录
创建预准备映像,并使用这些预准备映像通过以下方式创建 MCS 计算机目录:
使用预准备映像创建 MCS 计算机目录的关键步骤如下:
- 创建映像定义以及初始映像版本。
- 使用映像版本作为预准备映像来创建目录
Use Web Studio
创建映像定义和初始映像版本
要创建映像定义和初始映像版本,请执行以下操作:
- 在 Studio 中,转到“映像”节点,然后单击“创建映像定义”。在“简介”页面上单击“下一步”。
- 在“映像定义”页面上,为映像定义指定“操作系统类型”和“会话类型”。
-
在“映像”页面上,选择“资源”(仅列出适用于所设置连接的资源)和要用作创建映像版本模板的主映像。您可以选中“使用计算机配置文件”复选框并选择一个计算机配置文件。
注意:
在选择映像之前,请验证主映像是否已安装 VDA 2311 或更高版本,并且 VDA 上已安装 MCSIO 驱动程序。
- 在“计算机规格”页面上,选择计算机大小。如果选择计算机配置文件,则可以看到从计算机配置文件派生的虚拟 CPU 计数,并且该计数不可更改。如果不选择计算机配置文件,则只能看到从主映像派生的内存大小。
- 在“网卡”页面上,为准备映像选择或添加网卡。对于每个网卡,选择一个关联的虚拟网络。如果不选择计算机配置文件,则默认选择与主映像关联的网卡。如果选择计算机配置文件,则网卡将从计算机配置文件派生,并且计数不可更改。
- 在“版本描述”页面上,输入所创建的初始映像版本的描述。
- 在“摘要”页面上,检查映像定义和所创建的初始映像版本的详细信息。输入映像定义的名称和描述。单击“完成”。
创建映像版本
映像版本提供了管理特定映像的不同迭代或更新的能力。这项功能使您能够针对不同目的维护映像的多个版本。
要从初始映像版本创建映像版本,请执行以下操作:
- 转到“映像”节点,选择映像版本或映像定义,然后单击“创建映像版本”。
- 在“映像”页面上,您可以更改同一托管连接中的托管单元,并重新选择该映像版本的主映像和计算机配置文件。
- 如果您希望映像版本的配置与初始配置的映像版本不同,则在“创建映像版本”对话框的“计算机规格”和“网卡”页面上配置设置。
- 添加映像版本的描述。单击“完成”。
注意:
如果映像版本创建因任何原因失败,底部“故障排除”选项卡提供“重试”选项。
共享准备好的映像
先决条件
共享准备好的映像使用冷迁移在 vCenter Server 实例之间复制映像。以下先决条件适用于属于不同托管连接的托管单元:
-
vCenter Server 之间的冷迁移:冷迁移要求两个环境都支持跨 vCenter 迁移。
- Both vCenter Servers must run vSphere 7.0 or later (vSphere 8.0+ recommended).
- 不需要增强型链接模式。
端口要求:确保以下端口已打开以进行迁移:
源 目标位置 端口 协议 用途 作为源的 vCenter 服务器 目标 vCenter 服务器 443 TCP vCenter 服务器之间的 API 通信 源 ESXi 主机 目标 ESXi 主机 902 TCP NFC(网络文件复制)数据传输 源 ESXi 主机 目标 ESXi 主机 8000 TCP vMotion 实时迁移流量 注意:
端口必须双向打开。迁移主要使用 NFC(端口 902)进行数据传输,使用端口 443 进行管理。端口 8000 可能会根据路径使用。源 vCenter 必须在克隆操作期间验证目标的 SSL 证书指纹。
VMkernel 内核适配器配置:
ESXi 虚拟化主机 所需服务 源 ESXi 主机 置备或管理方面 目标 ESXi 主机 与源相同的服务(置备或管理) 双方必须在 VMkernel 适配器上启用相同的流量服务(置备或管理)。不匹配会导致迁移失败。
在 vSphere Client 中,通过 主机 > 配置 > 网络 > VMkernel 适配器 进行验证。
已知限制:自定义存储策略在跨 vCenter 复制期间不会保留。将应用目标数据存储的默认存储策略。
-
启用 vTPM 的计算机配置文件:密钥提供程序兼容性。对于具有 vTPM 的配置文件,两个 vCenter Server 都必须访问兼容的密钥提供程序。
必备条件 详细信息 相同的密钥提供程序访问 目标 vCenter 必须能够访问与源相同的密钥提供程序,或者使用本机密钥提供程序作为桥接 密钥材料 对于外部 KMS:两个 vCenter 都必须注册到同一个 KMS 群集(或共享密钥材料的 KMS 群集) 本机密钥提供程序 在两个 vCenter 服务器上配置本机密钥提供程序。每个 vCenter 的本机密钥提供程序都是独立的,但 vSphere 接受此组合用于跨 vCenter 操作。如果源和目标不共享外部 KMS,本机密钥提供程序也可以充当桥梁。本机密钥提供程序在使用前必须在两个 vCenter 上进行备份。 注意:
本机密钥提供程序是最简单的选项。在两台服务器上配置并备份它。如果使用外部 KMS,请确保两个 vCenter 共享相同的群集或密钥材料。在为启用 vTPM 的目录启用映像共享之前,请在 vSphere Client 中的 vCenter > 配置 > 安全 > 密钥提供程序下验证密钥提供程序配置。
跨不同主机单元共享准备好的映像
要跨不同主机单元共享准备好的映像,请按照以下步骤操作:
- 右键单击映像版本,然后选择“管理映像共享”。列出了所选连接下的所有主机单元。映像版本创建来源的资源已禁用任何操作。
- 选择要共享映像的主机单元,然后单击“保存”。 “共享状态”列显示“正在进行”。
- 单击底部的“资源”选项卡以获取有关共享状态的更多详细信息。
注意:
当映像版本共享状态正在进行时,“删除映像版本”或“管理映像共享”选项将被禁用。
从“映像”节点创建计算机目录
使用“映像”节点中的“创建目录”选项,使用映像版本创建目录。
或者,您可以在“计算机目录”节点中创建目录时选择版本,链接到目录创建工作流中的准备好的映像选项。请参阅 从“计算机目录”节点创建计算机目录
要从“映像”节点创建 MCS 计算机目录,请执行以下操作:
- 选择一个映像版本,然后单击“创建目录”。在“简介”页面上单击“下一步”。
- 在桌面体验页面上,选择所需的桌面体验。
- 从映像页面到虚拟机页面,设置会根据所选映像版本预先选择。
- 请在后续页面中完成相关设置。
- 在摘要页面上,检查计算机目录的详细信息。输入计算机目录的名称和描述。单击完成。
- 转到计算机目录节点以查看创建的计算机目录。
从计算机目录节点创建计算机目录
要从计算机目录节点创建 MCS 计算机目录,请执行以下操作:
- 在左侧导航窗格中单击计算机目录。
- 单击创建计算机目录。计算机目录设置页面随即出现。依次单击简介、计算机类型和计算机管理页面上的下一步。
- 在映像页面上:
- 选择准备好的映像。
- 在准备好的映像下,选择映像定义的映像版本。
- 单击映像版本名称。要查看有关所选映像版本的更多详细信息,请单击带下划线的版本号。
- 如果所选映像版本配置了计算机配置文件,请选择一个计算机配置文件。如果所选映像版本未配置计算机配置文件,则无法选择使用计算机配置文件。
- 请在后续页面中配置各项设置。
- 在摘要页面上,检查计算机目录的详细信息。输入计算机目录的名称和描述。单击完成。
使用 PowerShell 脚本和管理工具
创建准备好的映像
创建准备好的映像版本规范的详细 PowerShell 命令如下:
-
使用
Test-ProvImageDefinitionNameAvailable command检查可用的映像定义名称。例如,Test-ProvImageDefinitionNameAvailable -ImageDefinitionName <string[]> <!--NeedCopy--> -
使用
New-ProvImageDefinition命令创建映像定义。例如,New-ProvImageDefinition -ImageDefinitionName image2 -OsType Windows -VdaSessionSupport SingleSession <!--NeedCopy--> -
使用
Add-ProvImageDefinitionConnection命令在指定的托管连接中为映像定义创建新配置。例如,Add-ProvImageDefinitionConnection -ImageDefinitionName image2 -HypervisorConnectionName VMware <!--NeedCopy--> -
使用
New-ProvImageVersion命令创建映像版本。例如,New-ProvImageVersion -ImageDefinitionName $ImageDefintion.ImageDefinitionName -Description "version 1" <!--NeedCopy--> -
使用
Add-ProvImageVersionSpec命令将主映像版本规范添加到映像版本。例如,$MasterImagePath = "XDHyp:\HostingUnits\vmware\win10-master.vm\win10-master-snap.snapshot" $SourceImageVersionSpec = Add-ProvImageVersionSpec -ImageDefinitionName $ImageVersion.ImageDefinitionName -ImageVersionNumber $ImageVersion.ImageVersionNumber -HostingUnitName vmware -MasterImagePath $MasterImagePath <!--NeedCopy-->注意:
对于一个托管单元,您只能向一个映像版本添加一个主映像版本规范。
-
使用
New-ProvImageVersionSpec命令从主映像版本规范创建准备好的映像版本规范。例如,New-ProvImageVersionSpec -SourceImageVersionSpecUid $SourceImageVersionSpec.ImageVersionSpecUid -NetworkMapping @{"0"="XDHyp:\HostingUnits\vmware\\DSwitch-VM Network.network"} -VMCpuCount 2 -VMMemoryMB 4096 -RunAsynchronously <!--NeedCopy--> -
您还可以使用
Add-ProvImageVersionSpecHostingUnit命令在同一托管连接中与其他托管单元共享准备好的映像版本规范。例如,Add-ProvImageVersionSpecHostingUnit -ImageVersionSpecUid xxxxxxx -HostingUnitName VMwareabc <!--NeedCopy-->
创建映像定义、映像版本和准备好的映像版本规范的完整 Powershell 命令集示例:
New-ProvImageDefinition -ImageDefinitionName image2 -OsType Windows -VdaSessionSupport Single
Add-ProvImageDefinitionConnection -ImageDefinitionName image2 -HypervisorConnectionName VMware
$imageVersion = New-ProvImageVersion -ImageDefinitionName image2
$SourceImageVersionSpec = Add-ProvImageVersionSpec -ImageVersionUid $imageVersion.ImageVersionUid `
-HostingUnitUid $hostingunit.HostingUnitUid `
-MasterImagePath "XDHyp:\HostingUnits\vmware\shuaiz-win10-master.vm\shuaiz-win10-master-snap.snapshot"
New-ProvImageVersionSpec -SourceImageVersionSpecUid $SourceImageVersionSpec.ImageVersionSpecUid `
-NetworkMapping @{"0"="XDHyp:\HostingUnits\vmware\\DSwitch-VMNetwork.network"} `
-VMCpuCount 2 -VMMemoryMB 4096
Add-ProvImageVersionSpecHostingUnit -ImageVersionSpecUid xxxxxxx -HostingUnitName VMwareabc
$PreparedImageVersionSpec = Get-ProvImageVersionSpec -ImageVersionUid $imageVersion.ImageVersionUid | Where SourceImageVersionSpecUid-eq $SourceImageVersionSpec.ImageVersionSpecUid
<!--NeedCopy-->
注意:
- 图像定义中的所有图像版本规范必须属于同一个托管单元。
- 一个图像版本只能有一个主图像版本规范和一个准备好的图像版本规范。
- 所有图像版本规范必须要么具有计算机配置文件,要么所有图像版本规范都不能具有计算机配置文件。
使用准备好的图像版本规范创建目录
使用 New-ProvScheme 命令从准备好的图像版本规范创建 MCS 计算机目录。例如,
New-ProvScheme -ProvisioningSchemeName <string> -ImageVersionSpecUid <Guid> -HostingUnitUid <Guid> -IdentityPoolUid <Guid> [-VMCpuCount <int>] [-VMMemoryMB <int>] [-UseWriteBackCache] [-NetworkMapping <Hashtable>] [-CleanOnBoot] [-Scope <string[]>] [-Metadata <Hashtable>] [-ServiceOffering <string>] [-SecurityGroup <string[]>] [-TenancyType <string>] [-MachineProfile <string>] [-CustomProperties <string>] [-ResetAdministratorPasswords] [-UseFullDiskCloneProvisioning] [-RunAsynchronously] [-PurgeJobOnSuccess] [-ProvisioningSchemeType <ProvisioningSchemeType>]
<!--NeedCopy-->
或者,
New-ProvScheme -ProvisioningSchemeName <string> -ImageVersionSpecUid <Guid> -HostingUnitName <string> -IdentityPoolName <string> [-VMCpuCount <int>] [-VMMemoryMB <int>] [-UseWriteBackCache] [-NetworkMapping <Hashtable>] [-CleanOnBoot] [-Scope <string[]>] [-Metadata <Hashtable>] [-ServiceOffering <string>] [-SecurityGroup <string[]>] [-TenancyType <string>] [-MachineProfile <string>] [-CustomProperties <string>] [-ResetAdministratorPasswords] [-UseFullDiskCloneProvisioning] [-RunAsynchronously] [-PurgeJobOnSuccess] [-ProvisioningSchemeType <ProvisioningSchemeType>]
<!--NeedCopy-->
在 VMware 中使用准备好的图像版本规范创建目录的示例:
New-ProvScheme -ProvisioningSchemeName assignimage -ImageVersionSpecUid $PreparedImageVersionSpec.ImageVersionSpecUid `
-HostingUnitName $hostingunit.c-IdentityPoolName $IdentityPool.IdentityPoolName `
-CleanOnBoot -Scope @() -SecurityGroup @() -VMCpuCount 2 -VMMemoryMB 8192 `
-NetworkMapping @{"0"="XDHyp:\HostingUnits\vmware\\DSwitch-VM Network.network"}
<!--NeedCopy-->
创建目录的完整 Powershell 命令集示例:
$Catalog = New-BrokerCatalog -AllocationType "Random" -IsRemotePC $False -MinimumFunctionalLevel "L7_20" -Name "vmwarecatalog" -PersistUserChanges "Discard" -ProvisioningType "MCS" -Scope @() -SessionSupport "MultiSession"
$IdentityPool = New-AcctIdentityPool -AllowUnicode -Domain "vmware.local" -IdentityPoolName "vmwarecatalog" -IdentityType "ActiveDirectory" -NamingScheme "vmware##" -NamingSchemeType "Numeric" -Scope @()
$PreparedImageVersionSpec = Get-ProvImageVersionSpec -ImageDefinitionName image2 -ImageVersionNumber 1 -Filter "PreparationType -eq 'Mcs'"
$Task = New-ProvScheme -ProvisioningSchemeName vmwarecatalog -ImageVersionSpecUid $PreparedImageVersionSpec.ImageVersionSpecUid -HostingUnitName vmware -IdentityPoolName vmwarecatalog -CleanOnBoot -Scope @() -SecurityGroup @() -NetworkMapping @{"0"="XDHyp:\HostingUnits\vmware\\DSwitch-VM Network.network"} -VMCpuCount 2 -VMMemoryMB 4096 -RunAsynchronously
Get-ProvTask -TaskId $Task.TaskId
$ProvScheme = Get-ProvScheme -ProvisioningSchemeName vmwarecatalog
Set-BrokerCatalog -Name $Catalog.Name -ProvisioningSchemeId $ProvScheme.ProvisioningSchemeUid
<!--NeedCopy-->