Contact Info

Crumbtrail

ActiveXperts.com » Administration » Scripts » WMI » Perl

Win32-PerfRawData-RemoteAccess-RASTotal - WMI Perl sample

The foundations for Manageability in Windows 2019/2016/2012/2008 and Windows 10/7/XP are 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.

On this site, you can find many WMI samples.

The Win32_PerfRawData_RemoteAccess_RASTotal WMI class can be used in ActiveXperts Network Monitor to monitor your servers.


Win32-PerfRawData-RemoteAccess-RASTotal

Description

The Win32_PerfRawData_RemoteAccess_RASTotal raw data performance counter class represents raw data counters that combine values for all ports of the Remote Access service (RAS) device on the computer. This class is shown as the RAS Total object in System Monitor. The WMI source of its data is the high-performance Performance Counter Provider. The original data source is the RemoteAccess performance library. The corresponding formatted data class is Win32_PerfFormattedData_RemoteAccess_RASTotal. This class was added for Windows 2000.

Example(s)

  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_PerfRawData_RemoteAccess_RASTotal", "WQL",
                  wbemFlagReturnImmediately | wbemFlagForwardOnly);

   foreach my $objItem (in $colItems) {
      print "AlignmentErrors: $objItem->{AlignmentErrors}\n";
      print "BufferOverrunErrors: $objItem->{BufferOverrunErrors}\n";
      print "BytesReceived: $objItem->{BytesReceived}\n";
      print "BytesReceivedPerSec: $objItem->{BytesReceivedPerSec}\n";
      print "BytesTransmitted: $objItem->{BytesTransmitted}\n";
      print "BytesTransmittedPerSec: $objItem->{BytesTransmittedPerSec}\n";
      print "Caption: $objItem->{Caption}\n";
      print "CRCErrors: $objItem->{CRCErrors}\n";
      print "Description: $objItem->{Description}\n";
      print "FramesReceived: $objItem->{FramesReceived}\n";
      print "FramesReceivedPerSec: $objItem->{FramesReceivedPerSec}\n";
      print "FramesTransmitted: $objItem->{FramesTransmitted}\n";
      print "FramesTransmittedPerSec: $objItem->{FramesTransmittedPerSec}\n";
      print "Frequency_Object: $objItem->{Frequency_Object}\n";
      print "Frequency_PerfTime: $objItem->{Frequency_PerfTime}\n";
      print "Frequency_Sys100NS: $objItem->{Frequency_Sys100NS}\n";
      print "Name: $objItem->{Name}\n";
      print "PercentCompressionIn: $objItem->{PercentCompressionIn}\n";
      print "PercentCompressionOut: $objItem->{PercentCompressionOut}\n";
      print "SerialOverrunErrors: $objItem->{SerialOverrunErrors}\n";
      print "TimeoutErrors: $objItem->{TimeoutErrors}\n";
      print "Timestamp_Object: $objItem->{Timestamp_Object}\n";
      print "Timestamp_PerfTime: $objItem->{Timestamp_PerfTime}\n";
      print "Timestamp_Sys100NS: $objItem->{Timestamp_Sys100NS}\n";
      print "TotalConnections: $objItem->{TotalConnections}\n";
      print "TotalErrors: $objItem->{TotalErrors}\n";
      print "TotalErrorsPerSec: $objItem->{TotalErrorsPerSec}\n";
      print "\n";
   }
}