Powershell: получить вывод из Receive-Job
У меня есть коллекция рабочих мест, которые работают. Когда они завершаются, я использую receive-job, и он записывает вывод на экран. Я хотел бы взять этот вывод и записать его в файл. Я не хочу использовать вывод, полученный во время выполнения заданий, потому что при одновременном запуске нескольких заданий регистрация будет разбросана. Get-Job | Receive-Job печатает вывод в хорошо организованной манере.
Я пробовал все следующее, и никакой вывод не записывается в файл или хранится в переменной, он просто идет на экран:
#Wait for last job to complete
While (Get-Job -State "Running") {
Log "Running..." -v $info
Start-Sleep 10
}
Log ("Jobs Completed. Output:") -v $info
# Getting the information back from the jobs
foreach($job in Get-Job){
Receive-Job -Job $job | Out-File c:\Test.log -Append
$output = Receive-Job -Job $job
Log ("OUTPUT: "+$output)
Receive-Job -Job $job -OutVariable $foo
Log ("FOO: "+$foo)
}
РЕДАКТИРОВАТЬ: После удаления комментария Кейта я удалил дополнительные вызовы Receive-Job из раздела foreach для следующего:
# Getting the information back from the jobs
foreach($job in Get-Job){
Receive-Job -Job $job -OutVariable temp
Write-Host ("Temp: "+$temp)
$temp | Out-File -FilePath c:\Test.log -Append
}
Я также подтвердил, что не использую Receive-Job где-либо еще в сценарии. Тем не менее, запись-хост $ temp и выходной файл по-прежнему не выводят.