L,要写SQL语句。 当然,用PowerShell也可以实现差不多的功能,本人技术非常一般,下面脚本对我来说还是比较好用的。 首先PowerShell输出Hyper-V主机的条目信息是这样的
Get-VMNetworkAdapter-all
这个命令输出的结果有多悲剧我就不说了,东西太多。 所以我很机智的加了一些东西,”|”是管道的作用,把结果输出到后面的参数,后面的意思是只输出虚拟机名称和IP地址。
Get-VMNetworkAdapter-all|Select-ObjectVMname,IPAddresses|Format-Table
既然已经很机智了,再来一点吧
Get-VMNetworkAdapter-all|Select-ObjectVMname,IPAddresses|Format-Table>>\192.168.15.194d$33.csv
直接将内容输出到一个共享文件夹的.csv文件中。 ===========更高档的来了?====================== 用下面这个句子,可以一次输出三台主机的IP地址和虚拟机名称列表,名称为目标主机的d盘下的以主机名为名称的.csv,这时候注意下,输出结果是分散在不同主机上的。
Invoke-Command-ComputerNamehahv1,hahv2,hahv3-Command{Get-VMNetworkAdapter-all|Select-ObjectVMname,IPAddresses|Format-Table>d:$env:COMPUTERNAME.csv}
我们总结一下,写一个.ps1文件,也就是PowerShell的批处理脚本
|
还有很机智的小伙伴说,原来PowerShell里面可以运行cmd啊,是啊没错,不过你如果不是.xxx.cmd这种方式运行,程序就跑到cmd里面,回不到ps了,后续内容不执行,非常悲剧。
另外echo “copy *.csv hv.csv /y” >d:/cp.cmd 这种方法其实是错的,正确的是下面的!!
echo“asdf3434sdsf3434df”|Out-Filed:/11.txt-EncodingDefault-Append
你要问为什么这么写,是因为一行没什么事儿,多了的话,这乱码问题解决不了啊。 另外这种方式还有一个机智的地方,它是追加写入的,就是这命令你输入一次,他追加一行。 如果你想保证脚本干净,记得运行前来一个del cp.cmd 只有这样才会创建新的文件。
================下面内容是白送的=========================== 依然是报错一小波
Id10619,这个问题出错实在是太机智了。比如你VHD模板里面的管理员用户名是administrator,但是你在VM模板中想把管理员设置成admin,很遗憾,这不行。 如果你拿到的是别人做给你的VHD,你的好***很邪恶的修改了administrator的名称,变成了xyz,那么你正常部署必然会失败。
Id802,被其他人使用中,这个毫无办法,重启vmm服务器解决(其实是库服务器上的文件被其他人使用,但是重启VMM是有效的。)
Id2904找不到路径,这个问题是这样的,你想把虚拟机部署到目标主机的D:HYPERV目录下,但是,但是,你必须要提前创建这个目录才可以。
转载于:https://blog.51cto.com/jiushu/1419862