利用vSpherePowerCLI批量克隆部署虚拟机公司需要为项目搭建一个多客户端节点的虚拟测试环境,需要安装多台虚拟机,但是如果一台一台机器去手工部署,就太麻烦了。上网查找了相关资料之后,发现可以通过使用vSphereCLI批量克隆部署虚拟机,具体的脚本如下:[plain]viewplaincopy$vc='192.168.1.103'#VCenterIPConnect-VIServer-Server$vc-usernamemyUsrName-PasswordmyPassword$vmhost=192.168.1.11#esxihost$namestart=myClient$template=myTemplate1$datastore=datastore2$custsysprep=Get-OSCustomizationSpecmyCustSpec$ipstart=192.168.1.$endipscope=100..150#循环生成50台虚拟机foreach($endipin$endipscope){$ip=$ipstart+$endip$name=$namestart+$endip$custsysprep|Set-OScustomizationSpec-NamingSchemefixed-NamingPrefix$name$custsysprep|Get-OSCustomizationNicMapping|Set-OSCustomizationNicMapping-IpModeUseStaticIP-IpAddress$ip-SubnetMask255.255.255.0-Dns192.168.1.1-DefaultGateway192.168.1.1New-vm-vmhost$vmhost-Name$name-Template$template-Datastore$datastore-OSCustomizationspec$custsysprep}将上面的脚本保存为“cloneClient.ps1”,然后打开VMWarevSpherePowerCLI,运行./cloneClient.ps1回车即可运行。这样通过一个脚本,就可以让机器自动来完成大批量重复性的工作了。-------------------------------------------与自定义规范管理有关的sysprep------------------------------------------------------我们克隆了50台主机,但是每台主机的名字和IP地址等是不能一样的,不然会有冲突,最后一个一个手工去改,还是会费时费力。我们可以通过vSphere的“自定义规范管理器”来进行主机生产策略的定制,定制好之后的策略可以保存下来供部署克隆虚拟机的时候使用。但是,我们部署克隆虚拟机的时候会发现自定义的规范是无法使用的,这是因为,默认情况下vCenter没有提供sysprep(关于sysprep具体请自行维基搜索学习,sysprep仅适用于Windows操作系统,linux还没有具体研究),我们需要手工去windows安装盘中将sysprep文件拷贝到vcenter主机上。以WindowsXP为例:浏览xp系统安装盘,进入\winxp_professional_sp3_x14-74070\SUPPORT\TOOLS\DEPLOY.CAB\,将该目录下的文件都拷贝进安装vcenter的主机上,如果vcenter安装在XP操作系统上,则拷贝进c:\DocumentsandSettings\VMware\VMwareVirtualCenter\sysprep\xp中,如果vcenter安装在WindowsServer2008操作系统上,则拷贝进c:\ProgramData\VMware\VMwareVirtualCenter\sysprep\xp中,然后就可以使用我们的自定义规范了。当然,自定义规范也可以通过PowerCLI命令行来实现,比如上面的脚本中“$custsysprep=Get-OSCustomizationSpecmyCustSpec“就是获取已有的规范,然后在下面进行修改,以满足每台虚拟机的不同特性。-------------------------------------------关于vSpherePowerCLI的安装和配置--------------------------------------------------默认情况下,vCenter主机上市没有安装vSpherePowerCLI的,需要先到VMWare官网上去下载VMwarevSpherePowerCLI的软件包,然后安装到vCenter主机上。然后启动VMwarevSpherePowerCLI,运行后提示:[html]viewplaincopyspanstyle=color:#ff0000;无法加载文件C:\ProgramFiles(x86)\VMware\Infrastructure\vSpherePowerCLI\Scripts\Initialize-PowerCLIEnvironment.ps1,因为在此系统中禁止执行脚本。有关详细信息,请参阅get-helpabout_signing。所在位置行:1字符:2+.C:\ProgramFiles(x86)\VMware\Infrastructure\vSpherePowerCLI\Scripts\Initialize-PowerCLIEnvironment.ps1+CategoryInfo:NotSpecified:(:)[],PSSecurityException+FullyQualifiedErrorId:RuntimeException/span我们可以通过get-executionpolicy查看本地执行策略,结果发现执行的策略是Restricted(默认策略),但该策略是不允许任何脚本执行的,我们想要用脚本进行虚拟机部署,该策略肯定不适合。[html]viewplaincopyPSC:\ProgramFiles(x86)\VMware\Infrastructure\vSpherePowerCLIget-executionpolicyRestrictedPSC:\ProgramFiles(x86)\VMware\Infrastructure\vSpherePowerCL我们可以通过set-executionpolicyremotesigned来将策略更改为remotesigned,[html]viewplaincopyPSC:\ProgramFiles(x86)\VMware\Infrastructure\vSpherePowerCLIset-executionpolicyremotesigned执行策略更改执行策略可以防止您执行不信任的脚本。更改执行策略可能会使您面临about_Execution_Policies帮助主题中所述的安全风险。是否要更改执行策略?[Y]是(Y)[N]否(N)[S]挂起(S)[?]帮助(默认值为“Y”):yPSC:\ProgramFiles(x86)\VMware\Infrastructure\vSpherePowerCLI备注:Restricted执行策略不允许任何脚本运行。AllSigned和RemoteSigned执行策略可防止WindowsPowerShell运行没有数字签名的脚本。再次运行VMwarevSpherePowerCLI,提示”Welcome“界面,工具正常启动。