Powershell脚本可存在500个错误

时间:2014-12-10 07:01:25

标签: powershell

我希望power shell脚本从多个服务器的IIS日志中获取所有500个条目。我编写了一个脚本,可以在前几个小时从单个服务器获取500个。有人可以检查并帮助我如何获取多个服务器。我有的剧本:

#Set Time Variable -60
$time = (Get-Date -Format "HH:mm:ss"(Get-Date).addminutes(-60))

# Location of IIS LogFile
#$servers = get-content C:\Users\servers.txt
$File = "\\server\D$\Logs\W3SVC89\"+"u_ex"+(get-date).ToString("yyMMddHH")+".log"

# Get-Content gets the file, pipe to Where-Object and skip the first 3 lines.
$Log = Get-Content $File | where {$_ -notLike "#[D,S-V]*" }

# Replace unwanted text in the line containing the columns.
$Columns = (($Log[0].TrimEnd()) -replace "#Fields: ", "" -replace "-","" -replace "\(","" -replace "\)","").Split(" ")

# Count available Columns, used later
$Count = $Columns.Length

# Strip out the other rows that contain the header (happens on iisreset)
$Rows = $Log | where {$_ -like "*500 0 0*"}

# Create an instance of a System.Data.DataTable
#Set-Variable -Name IISLog -Scope Global
$IISLog = New-Object System.Data.DataTable "IISLog"

# Loop through each Column, create a new column through Data.DataColumn and add it to the DataTable
foreach ($Column in $Columns) {
  $NewColumn = New-Object System.Data.DataColumn $Column, ([string])
  $IISLog.Columns.Add($NewColumn)
}

# Loop Through each Row and add the Rows.
foreach ($Row in $Rows) {
  $Row = $Row.Split(" ")
  $AddRow = $IISLog.newrow()
  for($i=0;$i -lt $Count; $i++) {
    $ColumnName = $Columns[$i]
    $AddRow.$ColumnName = $Row[$i]
  }
  $IISLog.Rows.Add($AddRow)
  }
 $IISLog | select @{n="DateTime"; e={Get-Date ("$($_.date) $($_.time)")}},sip,csuristem,scstatus | ? { $_.DateTime -ge $time } |Out-File C:\Users\Servers\results.csv

1 个答案:

答案 0 :(得分:0)

假设您的日志文件始终位于同一路径上,并且servers.txt包含您的服务器列表, 你可以阅读服务器列表,然后使用foreach循环对每个代码执行代码: 类似的东西(为每个服务器创建一个结果文件):

#Set Time Variable -60
$time = (Get-Date -Format "HH:mm:ss"(Get-Date).addminutes(-60))

# Location of IIS LogFile
$servers = get-content C:\Users\servers.txt

$servers| foreach{
    #inside the foreach loop $_ will represent the current server

    $File = "\\$_\D$\Logs\W3SVC89\"+"u_ex"+(get-date).ToString("yyMMddHH")+".log"

    # Get-Content gets the file, pipe to Where-Object and skip the first 3 lines.
    $Log = Get-Content $File | where {$_ -notLike "#[D,S-V]*" }

    # Replace unwanted text in the line containing the columns.
    $Columns = (($Log[0].TrimEnd()) -replace "#Fields: ", "" -replace "-","" -replace "\(","" -replace "\)","").Split(" ")

    # Count available Columns, used later
    $Count = $Columns.Length

    # Strip out the other rows that contain the header (happens on iisreset)
    $Rows = $Log | where {$_ -like "*500 0 0*"}

    # Create an instance of a System.Data.DataTable
    #Set-Variable -Name IISLog -Scope Global
    $IISLog = New-Object System.Data.DataTable "IISLog"

    # Loop through each Column, create a new column through Data.DataColumn and add it to the DataTable
    foreach ($Column in $Columns) {
      $NewColumn = New-Object System.Data.DataColumn $Column, ([string])
      $IISLog.Columns.Add($NewColumn)
    }

    # Loop Through each Row and add the Rows.
    foreach ($Row in $Rows) {
      $Row = $Row.Split(" ")
      $AddRow = $IISLog.newrow()
      for($i=0;$i -lt $Count; $i++) {
        $ColumnName = $Columns[$i]
        $AddRow.$ColumnName = $Row[$i]
      }
      $IISLog.Rows.Add($AddRow)
      }
     $IISLog | select @{n="DateTime"; e={Get-Date ("$($_.date) $($_.time)")}},sip,csuristem,scstatus | ? { $_.DateTime -ge $time } |Out-File C:\Users\Servers\$_results.csv

 }

请注意,这将在您的每台服务器上按顺序运行您的代码。如果您遇到持续时间问题,可以尝试使用invoke-command-asjob参数来启动异步代码