随笔 - 911  文章 - 5  评论 - 94  阅读 - 243万

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

}

posted on   momingliu11  阅读(2506)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
< 2013年1月 >
30 31 1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30 31 1 2
3 4 5 6 7 8 9

点击右上角即可分享
微信分享提示