Reporting CPU usage by saving it to a file with the VBScript filesystem object
Posted by: Jerry Lees
Last time, in my entry entitled Vbscript to check CPU and Processor performance counter statistics using WMI, I asked you to modify the code I gave to include the access method type in the function. If you haven’t read teh article, take a second to go back and look it over and digest the code because this article is identicle to that one, except some added features.
Again I got a rather quick response to the extra credit item that I placed at the end if the article. Basically, you just need to change the code in three places to accomplish this task. We could then use this code in our previous example to create a CSV file for trending and graphing of CPU usage on a server! Here is an example of the code to do this task.
I encourage you to play around with the various methods of file access both with an existing file and a new file that doesn’t exist.
Below is a working example of the code:
Option Explicit
On Error Goto 0
Dim strSrv, strQuery,Errors
Dim Counter, Timeframe, Delay
Delay = 1000 ‘1000 Milliseconds to a second
Timeframe = 300 ’seconds (5 minutes)
strSrv = “.”
For Counter = 1 To Timeframe
Errors = WriteTextFile (”c:\cpu-usagelog.csv”, GetFormattedCPU (strSrv), ForAppending)
WScript.Sleep Delay
NextConst ForReading = 1, ForWriting = 2, ForAppending = 8Function GetFormattedCPU(strSrv)
Dim objWMIService, Item, Proc, start
start = Now()
strQuery = “select * from Win32_PerfFormattedData_PerfOS_Processor”
Set objWMIService = GetObject(”winmgmts:\\” & StrSrv & “\root\cimv2″)
Set Item = objWMIService.ExecQuery(strQuery,,48)
WScript.Echo strQuery
For Each Proc In Item
GetFormattedCPU = GetFormattedCPU & Proc.PercentProcessorTime & “, “
wscript.echo “Processor ” & Proc.Name & ” = ” & Proc.PercentProcessorTime
Next
GetFormattedCPU = GetFormattedCPU & start
End FunctionFunction WriteTextFile (OutputFile, Data, AccessType)
Dim wrtlog, fso
On Error Resume Next
Set fso = CreateObject(”Scripting.FileSystemObject”)
Set wrtlog = fso.OpenTextFile (OutputFile, AccessType, true)
If Err.Number <> 0 Then
Set wrtlog = fso.OpenTextFile (OutputFile, ForWriting, true)
End If
wrtlog.WriteLine(Data)
WriteTextFile = Err.Number ‘You can use Err.Description here to debug.
On Error Goto 0
End FunctionYou now have all the pieces for a fully functional performance logging script, so you’re well on your way to being able to trobleshoot problems deep in the night without getting up and turning on perfmon. The creates a comma separated value file called cpu-usagelog.csv at the root of the C: drive while the output looks similar to the last time, except it is repeated and I put a time/date stamp in the code by using a new command, now().Also, pay attention to the error handling around the line that writes the data to the file, you’ll likely not see an error related to thefile not existing and you using the append access methods, becasue i’ve checked for it while opening a file. Lastly, notice the for next loop around the function call to call it Timeframe times (Timeframe is multiplied time the sleep Delay to get how long it will capture data). Also notice another new command:
Wscript.sleep, which basically pauses the execution for the number of milliseconds you specify in Delay.
Again, this code works perfectly. However, sometimes the formatting of the blog breaks the code if you copy and paste it into your editor. So, if you’d like to not type or troubleshoot any syntax errors due to the copy and paste problems I’ve provided the code for download for you. From here on out I will make the code available for download from my website’s (www.webstemsadministration.com) File Depot under the ITKE Blog Scripts category. Enjoy and happy scripting!
Extra credit: Try and modify this script to monitor something else that is useful to you. Let us all know how you’ve used it.



You must be logged-in to post a comment. Log-in/Register