Win32_Process perl sample code
The foundations for Manageability in Windows is Windows Management Instrumentation (WMI; formerly WBEM) and WMI extensions for Windows Driver Model (WDM).
ActiveXperts Network Monitor provides the ability to build monitor check routines based on WMI. ActiveXperts has collected more than a hundred WMI samples. You can use these samples as a base for new check routines you can write yourself. The Win32_Process WMI class can be used in ActiveXperts Network Monitor to monitor your servers.
Description
The Win32_Process WMI class represents a sequence of events on a Windows operating system. A descendent or member of this class is a sequence that consists of an interaction of one or more processors or interpreters, some executable code, and a set of inputs, for example, a client application running on a Windows system.
Sample Code
use strict; use Win32::OLE('in'); use constant wbemFlagReturnImmediately => 0x10; use constant wbemFlagForwardOnly => 0x20; my @computers = ("\localhost"); foreach my $computer (@computers) { print "\n"; print "==========================================\n"; print "Computer: $computer\n"; print "==========================================\n"; my $objWMIService = Win32::OLE->GetObject("winmgmts:\\\\$computer\\root\\CIMV2") or die "WMI connection failed.\n"; my $colItems = $objWMIService->ExecQuery("SELECT * FROM Win32_Process", "WQL", wbemFlagReturnImmediately | wbemFlagForwardOnly); foreach my $objItem (in $colItems) { print "Caption: $objItem->{Caption}\n"; print "CommandLine: $objItem->{CommandLine}\n"; print "CreationClassName: $objItem->{CreationClassName}\n"; print "CreationDate: $objItem->{CreationDate}\n"; print "CSCreationClassName: $objItem->{CSCreationClassName}\n"; print "CSName: $objItem->{CSName}\n"; print "Description: $objItem->{Description}\n"; print "ExecutablePath: $objItem->{ExecutablePath}\n"; print "ExecutionState: $objItem->{ExecutionState}\n"; print "Handle: $objItem->{Handle}\n"; print "HandleCount: $objItem->{HandleCount}\n"; print "InstallDate: $objItem->{InstallDate}\n"; print "KernelModeTime: $objItem->{KernelModeTime}\n"; print "MaximumWorkingSetSize: $objItem->{MaximumWorkingSetSize}\n"; print "MinimumWorkingSetSize: $objItem->{MinimumWorkingSetSize}\n"; print "Name: $objItem->{Name}\n"; print "OSCreationClassName: $objItem->{OSCreationClassName}\n"; print "OSName: $objItem->{OSName}\n"; print "OtherOperationCount: $objItem->{OtherOperationCount}\n"; print "OtherTransferCount: $objItem->{OtherTransferCount}\n"; print "PageFaults: $objItem->{PageFaults}\n"; print "PageFileUsage: $objItem->{PageFileUsage}\n"; print "ParentProcessId: $objItem->{ParentProcessId}\n"; print "PeakPageFileUsage: $objItem->{PeakPageFileUsage}\n"; print "PeakVirtualSize: $objItem->{PeakVirtualSize}\n"; print "PeakWorkingSetSize: $objItem->{PeakWorkingSetSize}\n"; print "Priority: $objItem->{Priority}\n"; print "PrivatePageCount: $objItem->{PrivatePageCount}\n"; print "ProcessId: $objItem->{ProcessId}\n"; print "QuotaNonPagedPoolUsage: $objItem->{QuotaNonPagedPoolUsage}\n"; print "QuotaPagedPoolUsage: $objItem->{QuotaPagedPoolUsage}\n"; print "QuotaPeakNonPagedPoolUsage: $objItem->{QuotaPeakNonPagedPoolUsage}\n"; print "QuotaPeakPagedPoolUsage: $objItem->{QuotaPeakPagedPoolUsage}\n"; print "ReadOperationCount: $objItem->{ReadOperationCount}\n"; print "ReadTransferCount: $objItem->{ReadTransferCount}\n"; print "SessionId: $objItem->{SessionId}\n"; print "Status: $objItem->{Status}\n"; print "TerminationDate: $objItem->{TerminationDate}\n"; print "ThreadCount: $objItem->{ThreadCount}\n"; print "UserModeTime: $objItem->{UserModeTime}\n"; print "VirtualSize: $objItem->{VirtualSize}\n"; print "WindowsVersion: $objItem->{WindowsVersion}\n"; print "WorkingSetSize: $objItem->{WorkingSetSize}\n"; print "WriteOperationCount: $objItem->{WriteOperationCount}\n"; print "WriteTransferCount: $objItem->{WriteTransferCount}\n"; print "\n"; } }sub WMIDateStringToDate(strDate) { return "blah"; }