PowerShell批量重启计算机
在此例中,分为以下两个部分:
1.获取计算机列表,对其进行重启;
2.检查计算机是否重启成功
先看第一部分,如果对计算机(192.168.12.2)进行重启,可以通过调用WMI实现,命令如下:
$j = get-wmiobject -class win32_OperatingSystem -namespace "root\cimv2" -computer192.168.12.2 $j.reboot() |
注:WMI命令提供了到Windows管理规范(WMI)的简单命令行接口,可以很方便的对计算机进行管理,如操作系统、硬件组件等。此处所使用的 “win32_OperatingSystem”类,不仅包含了Reboot(重启)、Shutdown(关机)等方法,还包含有Version(版本)、SerialNumber(序列号)等属性。
使用“get-member”可以获取对象的属性和方法,如运行如下命令:
get-wmiobject -class win32_OperatingSystem |get-member
可得查询到“win32_OperatingSystem”所支持的属性和方法,其中就包含了Reboot和Shutdown等方法。
运行结果:
如果要对多台计算机进行重启,则可以先将IP地址保存在记事本中,然后使用“get-conent”命令读取,接下来再使用“foreach”对每台计算机进行处理,命令如下:
#计算机IP地址列表保存在c:\server.txt文件中 $serverlist = get-content c:\server.txt #每个IP地址保存到$s变量中 foreach ($s in $serverlist) { $j = get-wmiobject -class win32_OperatingSystem -namespace "root\cimv2" -computer $s $j.reboot() } |
再看第二部分,检查计算机是否启动成功,可以通过查询系统事件日志得出系统启动时间,命令如下:
get-winevent -logname system |where {$_.id -eq 6013}
查询ID为6013的系统日志,可以得出系统启动时间,如下:
在此我们需要对查询结果进行过滤,只查询日志创建时间晚于当前时间1小时的事件日志,命令如下:
get-winevent -logname system -computername $s |where {$_.id -eq 6013 -and $_.timecreated -gt (get-date).addminutes(-60)} |
如果对多台计算机进行查询,则命令如下:
foreach ($s in $serverlist) { $starttime = get-winevent -logname system -computername $s |where {$_.id -eq 6013 -and $_.timecreated -gt (get-date).addminutes(-60)} #将计算机IP地址和启动时间输出到c:\server_result.txt文件中 "$s " + $starttime.message | out-file -filepath c:\server_result.txt -append } |
一台计算机重启时间大概5分钟即可,如果计算机数量较多,则可自行去估算所需要的时间,等计算机重启完成后再去查询此事件日志,可以使用“Start-Sleep”命令进行延时。
综合以上两个步骤,完整的脚本命令如下:
$serverlist = get-content c:\server.txt foreach ($s in $serverlist) { $j = get-wmiobject -class win32_OperatingSystem -namespace "root\cimv2" -computer $s $j.reboot()}
#10分钟后再查询系统启动时间 Start-Sleep -s 600
foreach ($s in $serverlist) { $starttime = get-winevent -logname system -computername $s |where {$_.id -eq 6013 -and $_.timecreated -gt (get-date).addminutes(-29)} "$s " + $starttime.message | out-file -filepath c:\server_result.txt -append } |