'----------------------------------------
On Error Resume Next
dim iCpuUsePercentage'記錄CPU使用率
dim iSecond'記錄使用率等于100所持續的時間
dim objFileStream'txt文本讀寫流,用于記錄日志
dim objTextFileWriter'txt寫對象
dim objShell'Shell'對象,用于執行指定程序
dim objFileInfo'文件信息對象,用于獲取文件大小信息
dim bIsExecuteBat'是否已經運行過bat文件,下次重置0之前只執行一次批處理
iSecond=0'初始值為0
bIsExecuteBat=False
set objFileStream =CreateObject("Scripting.Filesystemobject")'創建文件系統對象
set objTextFileWriter=objFileStream.opentextfile("log.txt",8,True)'在腳本相同位置以追加方式打開日志文件,如果不存在,則創建日志文件
While True
Set objProc = GetObject("winmgmts:\\.\root\cimv2:win32_processor='cpu0'")'獲取第一個CPU對象
iCpuUsePercentage=objProc.LoadPercentage'獲取CPU使用率
objTextFileWriter.WriteLine("【" Now "】CPU使用率:" iCpuUsePercentage "%,使用率超80%持續時間:" CStr(iSecond))
'統計累計CPU使用率達到80以上的持續次數,一旦有小于80的,次數歸0
if iCpuUsePercentage>=80 then
iSecond=iSecond+1
else
iSecond=0
bIsExecuteBat=False'重置0之后,批處理可以再次執行
end if
if iSecond>=30 And bIsExecuteBat=False then
objTextFileWriter.WriteLine("CPU使用率達80%持續時間超過30秒!!")
'調用指定的批處理程序
set objShell=CreateObject("WScript.shell")
objShell.run "c:\email.bat"
bIsExecuteBat=True'標記已經執行過bat文件
end if
set objFileInfo=objFileStream.getfile("Log.txt")
'日志文件大于2M時,重新建立日志文件
if (objFileInfo.size/1024/1024) >=2 then
'先關閉文件才能操作
objTextFileWriter.close
objFileStream.MoveFile "Log.txt",Replace(Replace(Replace(Now,":",""),"-","")," ","") "BackLog.txt"
'重新打開日志文件
set objTextFileWriter=objFileStream.opentextfile("log.txt",8,True)
end if
Wend