
私はPowerShellを使っていて、C#からスクリプトを呼び出しています。異なるサーバーからログをコピーしようとしています。
foreach($server in $args)
{
$destination = "\\$server\$path"
if(!(Test-Path $destination))
{
New-Item -ItemType directory -Path $destination
}
foreach($log in $logsTaskAgent)
{
Write-Host "Backup $log log $server"
$filename = "{0}{1}_{2}_{3}.evt" -f $destination,$server,$log,$date
Write-Host "Filename: $filename"
if($password -and $userName)
{
$logFile = Get-WmiObject Win32_NTEventlogFile -ComputerName $server -Credential $credential -ErrorAction SilentlyContinue | where-object { $_.logfilename -eq $log }
Write-Output "continue"
if($logFile)
{
$logFile.PSBase.Scope.Options.EnablePrivileges = $true
$logFile.backupeventlog($filename)
}
else
{
Write-Output "Error on server: $server for log: $log"
}
}
}
これは完璧に動作しますが、資格情報に問題があると例外がスローされますが、サーバーが多数あるため、例外を無視して他のサーバーを続行したいので、続行したいのですが、何が間違っているのかわかりませんか? 私の理解では、-ErrorAction Silentlycontinue でうまくいくはずですが、そうではありません :(
編集: 修正
最終的に、Johan de Haan の回答と非常に似たものになったので、それを回答として採用します... 変更されたコードは次のとおりです。
foreach($server in $args)
{
try
{
$destination = "\\$server\$path"
if(!(Test-Path $destination))
{
New-Item -ItemType directory -Path $destination
}
foreach($log in $logsTaskAgent)
{
Write-Host "Backup $log log $server"
$filename = "{0}{1}_{2}_{3}.evt" -f $destination,$server,$log,$date
Write-Host "Filename: $filename"
if($password -and $userName)
{
$logFile = Get-WmiObject Win32_NTEventlogFile -ComputerName $server -Credential $credential -ErrorAction SilentlyContinue | where-object { $_.logfilename -eq $log }
Write-Output "continue"
if($logFile)
{
$logFile.PSBase.Scope.Options.EnablePrivileges = $true
$logFile.backupeventlog($filename)
}
else
{
Write-Output "Error on server: $server for log: $log"
}
}
}
}
catch
{
Write-Output "Error while retrieving log Object from server $server : $($_.Exception.Message)"
continue
}
$destination = ""
}
答え1
try/catch を使用し、break を使用して次のサーバーに進みます。
foreach($server in $args){
$destination = "\\$server\$path"
if(!(Test-Path $destination))
{
New-Item -ItemType directory -Path $destination
}
foreach($log in $logsTaskAgent)
{
Write-Host "Backup $log log $server"
$filename = "{0}{1}_{2}_{3}.evt" -f $destination,$server,$log,$date
Write-Host "Filename: $filename"
if($password -and $userName) {
try{
$logFile = Get-WmiObject Win32_NTEventlogFile -ComputerName $server -Credential $credential -ErrorAction Stop | where-object { $_.logfilename -eq $log }
} catch {
Write-Warning "Error while retrieving WMI Object: $($_.Exception.Message)"
break #this way you break out of the first loop, continuing in the foreach ($server in args loop)
}
Write-Output "continue"
if($logFile) {
$logFile.PSBase.Scope.Options.EnablePrivileges = $true
$logFile.backupeventlog($filename)
} else {
Write-Output "Error on server: $server for log: $log"
}
}
}
}