Using Powershell to search for specific strings in the last x lines of very large log files

前端 未结 3 1126
别那么骄傲
别那么骄傲 2021-01-18 18:13

I have a requirement that I have not found a solution or assistance for on the forums so far...

The issue: I monitor real time systems and these generate a number of

相关标签:
3条回答
  • 2021-01-18 18:30

    If you use PowerShell 3.0 or newer, you can use a combination of the get-content and select-string commandlets to get the same functionality. Since version 3.0, get-content support a -tail option that only returns the last n lines of a file in an efficient way. Using this, you can reimplement the Perl script above with the following (searching in the last 1000 lines):

    # Returns the number of occurrences
    (get-content logfile.txt -Tail 1000 | select-string -pattern "No packet received from EISEC Client").Length
    
    0 讨论(0)
  • 2021-01-18 18:36

    To seek backwards, this contribution to the Poshcode repository appears to be a good match for your requirements:

    # Name: Get-Tail.ps1
    # Author: William Stacey
    # Created: 02/22/2007
    # Description: Gets the last N lines of a file. Does scan from end-of-file so works on large files. Also has a loop flag that prompts for refresh.
    
    function Get-Tail([string]$path = $(throw "Path name must be specified."), [int]$count = 10, [bool]$loop = $false)
    {
        if ( $count -lt 1 ) {$(throw "Count must be greater than 1.")}
        function get-last
        {
            $lineCount = 0
            $reader = new-object -typename System.IO.StreamReader -argumentlist $path, $true
            [long]$pos = $reader.BaseStream.Length - 1
    
            while($pos -gt 0)
            {
                $reader.BaseStream.Position = $pos
                if ($reader.BaseStream.ReadByte() -eq 10)
                {
                    if($pos -eq $reader.BaseStream.Length - 1)
                    {
                        $count++
                    }
                    $lineCount++
                    if ($lineCount -ge $count) { break }
                }
                $pos--
            } 
    
            if ($lineCount -lt $count)
            {
                $reader.BaseStream.Position = 0
            }
    
            while($line = $reader.ReadLine())
            {
                $lines += ,$line
            }
    
            $reader.Close()
            $lines
        }
    
        while(1)
        {
            get-last
            if ( ! $loop ) { break }
            $in = read-host -prompt "Hit [Enter] to tail again or Ctrl-C to exit"
        }
    }
    
    0 讨论(0)
  • 2021-01-18 18:46

    PSCX has a cmdlet named Get-FileTail which efficiently gets the last lines of a file and thus avoiding reading the complete file beforehand.

    0 讨论(0)
提交回复
热议问题