I believe this is might be a permissions problem but not sure where to look anyone have any ideas? Thanks in advance! Subroutine:line 99: $EventLog->GetOldest(\$first) || die $!;
sub server_events { print_header(); print"<h2>SysAdmin Tools v0.1 (beta) </h2>\n"; my $servername = $q->param('servername') || 'localhost'; my $eventtype = $q->param('eventtype') || 'System'; my $eventquan = $q->param('eventquan') || '10'; print qq{<b>$servername is Server </b><br>}; print qq{<b>$eventtype is Event Type </b><br>}; print qq{<b>$eventquan is Event Quantity </b><br>}; my ($EventLog, $count, $first, $key); $first = $count = 0; my $event={ 'Source' => NULL, 'Computer' => NULL, 'Length' => NULL, 'Category' => NULL, 'RecordNumber' => NULL, 'TimeGenerated' => NULL, 'Timewritten' => NULL, 'EventID' => NULL, 'EventType' => NULL, 'ClosingRecordNumber' => NULL, 'Strings' => NULL, 'Data', => NULL, }; $EventLog = new Win32::EventLog( "$eventtype","$servername" ) || d +ie $!; $EventLog->GetOldest(\$first) || die $!; $EventLog->GetNumber(\$count) || die $!; $EventLog->Read((EVENTLOG_SEEK_READ | EVENTLOG_BACKWARDS_READ),$fi +rst+$count,$event); for my $i ($first+$count-$eventquan+1..$first+$count) { $EventLog->Read((EVENTLOG_SEQUENTIAL_READ|EVENTLOG_BACKWARDS_READ) +,0,$event); my ($sec,$min,$hour,$mday,$mon,$year,$sday,$yday,$isdst) = localti +me($event->{'TimeGenerated'}); print sprintf("%15s -> %02d\-%02d\-%02d, %02d:%02d\n",'timestamp', +$year,$mon+1,$mday,$hour,$min); #to get a readable EventId $event->{'EventID'} = $event->{'EventID'} & 0xffff; foreach $key ('RecordNumber','Category','Source','EventID', 'Event +Type', 'Strings', 'Data') { print sprintf( "%15s -> %s\n",$key, $event->{$key} ); print "<br>" } print "\n<br>"; } }
In reply to win32::eventlog file descriptor errors on IIS Server by jrdeinhard
| For: | Use: | ||
| & | & | ||
| < | < | ||
| > | > | ||
| [ | [ | ||
| ] | ] |