I'm trying to get a better understanding of how powershell handles jobs.
Both of these article posts helped a lot:
However, with the following sample script, I am getting unexpected results while calling Receive-Job. I expect a result on each line, but sometimes I see multiple results per line or extra blank carriage returns. Any idea on how to write out just the information that streams in from the console from each job?
$loops = 1..10
$jobs = new-object System.Collections.ArrayList
$loops | % {
$jobs.add(
(start-job -ScriptBlock {
param($list)
$list | % {
sleep -seconds (get-random -Maximum 3 -Minimum 1)
write-host "Number is: $_"
}
} -ArgumentList (,$loops))
) | out-null
}
while ($jobs.count -gt 0)
{
if ($jobs -ne $null)
{
$list = $jobs | ? { $_.HasMoreData -eq $true }
$list | % { Receive-Job -Job $_ }
$list2 = $jobs.Clone() | ? { $_.State -eq "Completed" }
$list2 | % {
$jobs.Remove($_) | out-null
}
$list = $null
}
}
Output can be...
Number is: 1 Number is: 1 Number is: 2
Or sometimes...
Number is: 1 Number is: 2 Number is: 1Number is: 2 Number is: 1Number is: 2Number is: 2