1文件说明
2 vSphere powercli的安装和配置
3个powercli通用命令
4 创建自定义规范
5 虚拟机克隆与配置脚本
1 文档说明
使用Vsphere管理虚拟机,在进行虚拟机克隆及配置时,一般均为手动操作。克隆之后,虚拟机需进行vlan修改、基础os配置等,手动操作繁琐且需耗费大量时间,如机器名修改、IP地址修改,只能通过控制台操作(无法考虑文本,且反应较慢),且需要重启虚拟机,效率很低。
使用PowerCli命令行工具,通过编写脚本,封装虚拟机的克隆、设置编辑、OS配置等命令,执行后可实现虚拟机直接可访问,可有效提高配置效率。
并且,成熟的脚步,可供其他程序或平台调用,为实现虚拟机定制、自助或批量创建与配置提供技术支撑。
本文介绍PowerCli的安装、配置方法,验证技术可行性,提供示例脚本。
2 Vsphere PowerCli安装和配置
安装文件可从vmware官网下载,如PowerCli5.5、6.5。
双击软件包,默认安装。
安装后,运行PowerCli,提示:“无法加载文件c:programFilesvmwareinfrastructurevspherepowerCLIscriptinitialize-vitoolkitenviroment.ps1,因为在此系统中禁止执行脚本。有关信息,请查阅“get-help about_signing”。
通过get-executionpolicy查看本地执行策略
更改执行策略
更改为RemoteSigned,执行策略
备注:
Restricted 执行策略不允许任何脚本运行。
AllSigned和 RemoteSigned 执行策略可防止 Windows PowerShell 运行没有数字签名的脚本。
再次运行VMware vSphere PowerCLI,提示”Welcome“界面,工具正常启动。
(开启Power Cli的时间有点长)
3 PowerCli常用命令
已整理的PowerCli命令有225个,可参考官方网址:
常用的有 :
Connect-VIServer– 连接虚拟化平台
get-vmhost – 显示ESXi主机列表
get-cluster –显示群集列表
get-datastore– 显示存储列表
get-resourcepool– 显示资源池
get-vm – 显示虚拟机列表
get-virtualswitch– 显示虚拟交换机列表
start-vm\stop -vm – 启动或关闭虚拟机
new -vm – 创建虚拟机
get-template– 显示模板列表
get-oscustomizationspec– 显示自定义规范列表
get-vapp – 显示vapp 应用列表
get-folder – 显示文件夹列表
get-vicommand– 显示所有命令列表
4 创建自定义规范
若要实现脚本完成虚拟机IP配置,需使用自定义规范。通过vcenter client【视图】-【管理】-【自定义规范管理器】-创建自定义规范。以win2003 x64为例,创建步骤如下:
使用虚拟机名称
vCenter Server 创建的计算机名称与客户机操作系统正在运行的虚拟机名称相同。
如果名称超过 15 个字符,它将被截断。
产品密钥(仅供参考)
w2003x64 MR78C-GF2CY-KC864-DTG74-VMT73
w2003x86 JCGMJ-TC669-KCBG7-HB8X2-FXG7M
输入管理员密码
选择时区
(可选) 在运行一次页面上,指定用户首次登录客户机操作系统时运行的命令,然后单击下一步。
有关“运行一次”命令的更多信息,请参见 Microsoft Sysprep 文档。
选择典型设置,使用过程中,用脚本修改规范中的网络相关信息
拷贝sysprep:
在创建完规范后,我们还需要复制相应版本的sysprep到vCenter服务器的指定目录中,规范才可以使用。
Vcenter server 5(win2008)中指定目录为:C:\Documentsand Settings\All Users\Application Data\VMware\VMware VirtualCenter\sysprep 此目录下有对应的各个版本,我们所需要做的就是将server 2003 的sysprep程序拷到这个目录下的svr2003-64目录中。对于win2003x86,则拷贝至svr2003目录中。
sysprep文件从镜像中找,在\SUPPORT\TOOLS\DEPLOY.CAB中。
vsphere4.1相关目录为:c:\ProgramData\VMware\VMware VirtualCenter\sysprep
vsphere5.5 linux操作系统相关目录为:/etc/vmware-vpx/sysprep
至此自定义规范可以使用。
5 虚拟机克隆与配置脚本
编写并验证通过的脚本如下,执行后可完成虚拟机克隆及配置,或修改已存在虚拟机的机器名和IP配置,其中w2003x642为自定义规范。参考如下。
注意:若basevm为之前使用脚本克隆并配置的虚拟机,则使用basevm作为被克隆虚拟机前,需要开机一次,使虚拟机自动完成配置,方可用于克隆。不然会导致新虚拟机克隆后自动配置失败。
##执行前提1:需要在vcenter client创建自定义规范$basespec,vcenter server sysprep相关目录中存在win2003的sysprep文件.
##执行前提2:所操作的虚拟机、或模板需安装vmtools
##将脚本编写至**.ps1文件中,如clonenewvm.ps1,打开PowerCli命令行,执行./clonenewvm.ps1即可
##’#’为注释
##’#’为注释
$vc = ‘1.1.1.1’ #VCenter IP
##连接VC
Connect-VIServer -Server $vc -username “username”-Password “password”
##相关参数(以下为例,实际使用可通过其他方式或脚本配置),依次为资源池、克隆后配置的虚拟机名称、待克隆的虚拟机、IP地址、掩码、网关、DNS1、DNS2、VLAN、宿主机、存储、自定义规范
$pool=Get-ResourcePool -name ‘T01’
$name=’vmname’
$basevm=’basevmname’
$ip=’1.2.2.2′
$netmask=’255.255.255.0′
$gateway=’1.2.2.254′
$DNSA=’1.2.3.1′
$DNSA2=’1.2.3.2′
$network=’VLAN_1′
$vmhost=get-vmhost -vm $basevm
$storage=get-datastore -vm $basevm
$basespec=’w2003x642′
##临时规范文件
$specName = “tempSpec” + (Get-Random)
Get-OSCustomizationSpec -Name $basespec |New-OSCustomizationSpec -Name $specName -Type NonPersistent
##删除规范中原网络相关配置
Get-OSCustomizationSpec $specName |Get-OSCustomizationNicMapping | Remove-OSCustomizationNicMapping-Confirm:$false
##添加自定义的网络相关配置
New-OSCustomizationNicMapping -Spec $specName -IpModeUseStaticIP -IpAddress $ip -SubnetMask $netmask -DefaulTGateway $gateway -DNS$DNSA,$DNSA2
$osspec=Get-OSCustomizationSpec $specName
##基于模板创建虚拟机并配置
##New-VM -Name $name -VMHost $vmhost -Datastore$storage -OSCustomizationSpec $osspec -Template $Template -ResourcePool $pool
##仅配置当前已存在虚拟机
#Get-VM $name | set-vm -OSCustomizationSpec $spec
#Set-VM -vm $name -OSCustomizationSpec $osspec-Confirm:$false
##基于其他虚拟机克隆并配置
New-VM -VM $basevm -Name $name -VMHost $vmhost-Datastore $storage -OSCustomizationSpec $osspec -ResourcePool $pool
##配置vlan
Get-VM -Name $name | Get-NetworkAdapter |Set-NetworkAdapter -NetworkName $network -Confirm:$false
##删除临时规范文件
Remove-OSCustomizationSpec -Confirm:$false-customizationSpec (Get-OSCustomizationSpec -name $specName)
##启动虚拟机
#start-vm $name
##断开连接
Disconnect-VIServer $vc -confirm:$false
##出错时,日志查看方法
#$lastError = $error[0]
#$lastError | select *