Powershell - Tail Windows Event Log? Is it possible?

前端 未结 3 643
你的背包
你的背包 2021-02-05 11:56

How can i use powershell to tail a specific windows event log? Is it possible?

相关标签:
3条回答
  • 2021-02-05 12:26

    I've done this on occasion:

    $idx = (get-eventlog -LogName System -Newest 1).Index
    
    while ($true)
    {
      start-sleep -Seconds 1
      $idx2  = (Get-EventLog -LogName System -newest 1).index
      get-eventlog -logname system -newest ($idx2 - $idx) |  sort index
      $idx = $idx2
      }
    
    0 讨论(0)
  • 2021-02-05 12:28

    First, thank you Michael!

    Slight refinement for my use case that includes showing the entire multi-line message value.

        function Get-WinEventTail($Provider="JobRequestQueueConsumerBackgroundService", $ShowExisting=10) {
        $formatProperty = @{ expression={$_.TimeCreated}; label="TimeCreated"}, 
                          @{ expression={$_.Message}; label="Message"; width=100}
        if ($ShowExisting -gt 0) {
            $data = Get-WinEvent -ProviderName $Provider -max $ShowExisting
            if ($data) { 
                $data | sort RecordId | Format-Table -Property $formatProperty -Wrap
                $idx = $data[0].RecordId
            }
        }
        else {
            $idx = (Get-WinEvent -ProviderName $Provider -max 1).RecordId
        }
    
        while ($true)
        {
            start-sleep -Seconds 1
            $idx2  = (Get-WinEvent -ProviderName $Provider -max 1).RecordId
            if ($idx2 -gt $idx) {
                Get-WinEvent -ProviderName $Provider -max ($idx2 - $idx) | sort RecordId | Format-Table -Property $formatProperty -Wrap
            }
            $idx = $idx2
    
            # Any key to terminate; does NOT work in PowerShell ISE!
            if ($Host.UI.RawUI.KeyAvailable) { return; }
        }
    }
    
    Get-WinEventTail
    

    The -Wrap option was necessary to show a multi-line message, otherwise ellipsis would truncate the message at the end of the first line. Setting the column width did NOT help.

    0 讨论(0)
  • 2021-02-05 12:44

    Per MSDN docs:

    Get-WinEvent is designed to replace the Get-EventLog cmdlet on computers running Windows Vista and later versions of Windows. Get-EventLog gets events only in classic event logs. Get-EventLog is retained in Windows PowerShell for backward compatibility.

    And spurred on by my own need to tail a non-classic event log (would that be an event log nouveau perchance?) here is the wonderfully concise code of @mjolinor repurposed to use Get-WinEvent:

    Set-PSDebug -Strict
    function Get-WinEventTail($LogName, $ShowExisting=10) {
        if ($ShowExisting -gt 0) {
            $data = Get-WinEvent -provider $LogName -max $ShowExisting
            $data | sort RecordId
            $idx = $data[0].RecordId
        }
        else {
            $idx = (Get-WinEvent -provider $LogName -max 1).RecordId
        }
    
        while ($true)
        {
            start-sleep -Seconds 1
            $idx2  = (Get-WinEvent -provider $LogName -max 1).RecordId
            if ($idx2 -gt $idx) {
                Get-WinEvent -provider $LogName -max ($idx2 - $idx) | sort RecordId
            }
            $idx = $idx2
    
            # Any key to terminate; does NOT work in PowerShell ISE!
            if ($Host.UI.RawUI.KeyAvailable) { return; }
        }
    }
    

    I added in a few bells and whistles for convenience:

    • By default it shows the last 10 lines of the log initially, then concatenates new entries as they occur--you can adjust that to any number via the ShowExisting parameter.
    • It sorts records with oldest first (contrary to Get-WinEvent's default) due to the natural order that tail requires.
    • You can press any key to terminate (but not in PowerShellISE).
    0 讨论(0)
提交回复
热议问题