应用程序池死锁,占用cpu过高,VBS处理脚本

    技术2022-05-20  50

    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'初始值为0bIsExecuteBat=Falseset 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 & "%,使用率超30%持续时间:" & CStr(iSecond))  '统计累计CPU使用率达到30以上的持续次数,一旦有小于30的,次数归0 if iCpuUsePercentage>=30 then   iSecond=iSecond+1 else  iSecond=0  bIsExecuteBat=False'重置0之后,批处理可以再次执行 end if

     if iSecond>=5 And bIsExecuteBat=False then  objTextFileWriter.WriteLine("CPU使用率达30%持续时间超过5秒!!")   msgbox ("CPU使用率达30%持续时间超过5秒") '调用指定的批处理程序  set objShell=CreateObject("WScript.shell")   objShell.run "cmd /c @taskkill/IM w3wp.exe /f",0  '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 ifWend


    最新回复(0)