How to retrieve data from powershell runspace jobHow do I run my PowerShell scripts in parallel without using Jobs?PowerShell Start-Job outputKill process, then uninstall application--Can I do this with PowerShell, over 400 computers, from a txt file?Powershell query lastlogondate (lastlogontimestamp) returning mostly blank values (not matching the ADSIedit value for corresponding user attribute)More efficient way to retrieve Office365 data via PowershellPowershell execution policy within SQL ServerIs it possible to migrate Azure VM image from one Subscription to another Subscription?PowerShell: How to retrieve a specific property _exclusively_Powershell DSC File copy - Workgroup machinesPowershell fails to retrieve pwdLastSet from Active DirectoryGetting data from BCEDIT with Powershell

Multi tool use
Multi tool use

Where to draw the line between quantum mechanics theory and its interpretation(s)?

How do LIGO and VIRGO know that a gravitational wave has its origin in a neutron star or a black hole?

Can my 2 children, aged 10 and 12, who are US citizens, travel to the USA on expired American passports?

What are the advantages of luxury car brands like Acura/Lexus over their sibling non-luxury brands Honda/Toyota?

Gladys unchained

Why is "breaking the mould" positively connoted?

getline() vs. fgets(): Control memory allocation

Is any special diet a treatment of autism?

Kanji etymology of 毎?

Hostile Divisor Numbers

How does summation index shifting work?

Is there an age requirement to play in Adventurers League?

Mug and wireframe entirely disappeared

What was Bran's plan to kill the Night King?

Should homeowners insurance cover the cost of the home?

Notation: What does the tilde bellow of the Expectation mean?

Change in "can't be countered" wording

Nested loops to process groups of pictures

Is there precedent or are there procedures for a US president refusing to concede to an electoral defeat?

How can I get people to remember my character's gender?

Is an HNN extension of a virtually torsion-free group virtually torsion-free?

Would you use "llamarse" for an animal's name?

What is a common way to tell if an academic is "above average," or outstanding in their field? Is their h-index (Hirsh index) one of them?

Feasibility of lava beings?



How to retrieve data from powershell runspace job


How do I run my PowerShell scripts in parallel without using Jobs?PowerShell Start-Job outputKill process, then uninstall application--Can I do this with PowerShell, over 400 computers, from a txt file?Powershell query lastlogondate (lastlogontimestamp) returning mostly blank values (not matching the ADSIedit value for corresponding user attribute)More efficient way to retrieve Office365 data via PowershellPowershell execution policy within SQL ServerIs it possible to migrate Azure VM image from one Subscription to another Subscription?PowerShell: How to retrieve a specific property _exclusively_Powershell DSC File copy - Workgroup machinesPowershell fails to retrieve pwdLastSet from Active DirectoryGetting data from BCEDIT with Powershell






.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;








3















Trying to multithread some of my scripts that take a while to run. One example is getting the last login for a user. It checks all of our DC's and then returns the most recent time. We have quite a few and they are global so running sequentially takes a while.



I saw this answer How do I run my PowerShell scripts in parallel without using Jobs?



which got me going in setting up the runspace and running it but I am not sure how to get the data back.



This is what I have so far



$username = Read-Host "Enter the Users ID"
$dcs = Get-ADDomainController -Filter Name -like "*" | Select -expandproperty name
$Code =

Select -Expandproperty lastLogon

$rsPool = [runspacefactory]::CreateRunspacePool(1,8)
$rsPool.Open()
foreach($dc in $dcs)

$PSinstance = [powershell]::Create().AddScript($Code).AddArgument($username).AddArgument($dc)
$PSinstance.RunspacePool = $RunspacePool
$PSinstance.BeginInvoke()



So I just need to wait for each job to finish and then capture the results of each which is what I am not sure how to do



Edit: Also I had previously tried to do this with jobs but the code actually took longer than the normal scrip



$userName = Read-Host "Enter NTID: "

$time = 0


$dcs = Get-ADDomainController -Filter Name -like "*" | Select -expandproperty name


$scriptbox = Select -Expandproperty lastLogon



foreach($dc in $dcs)start-Job -ScriptBlock $scriptbox -ArgumentList $username,$dc


Get-Job | Wait-Job


Get-Job

$Data = ForEach ($Job in (Get-Job))

Receive-Job $Job

Remove-Job $Job




Foreach ($date in $Data)if($date -gt $time)$time = $date


$dt = [DateTime]::FromFileTime($time)

write-Host $username "last logged on at:" $dt









share|improve this question
























  • Why would you not want to use normal PowerShell job for this?

    – Jim B
    Jun 3 '16 at 12:35











  • Open to suggestions if there is an easier way to do what i'm trying to accomplish. All of my scripts thus far have all been very linear.

    – Bill Lindsay
    Jun 3 '16 at 12:37












  • Take a look at blogs.technet.microsoft.com/heyscriptingguy/2012/12/31/… seems to me that background jobs are what you are looking for

    – Jim B
    Jun 3 '16 at 12:41











  • Gotcha, yeah I had actually tried something along those lines but for some reason it actually takes longer to run than the linear code. Ill edit the original post with that code

    – Bill Lindsay
    Jun 3 '16 at 12:47

















3















Trying to multithread some of my scripts that take a while to run. One example is getting the last login for a user. It checks all of our DC's and then returns the most recent time. We have quite a few and they are global so running sequentially takes a while.



I saw this answer How do I run my PowerShell scripts in parallel without using Jobs?



which got me going in setting up the runspace and running it but I am not sure how to get the data back.



This is what I have so far



$username = Read-Host "Enter the Users ID"
$dcs = Get-ADDomainController -Filter Name -like "*" | Select -expandproperty name
$Code =

Select -Expandproperty lastLogon

$rsPool = [runspacefactory]::CreateRunspacePool(1,8)
$rsPool.Open()
foreach($dc in $dcs)

$PSinstance = [powershell]::Create().AddScript($Code).AddArgument($username).AddArgument($dc)
$PSinstance.RunspacePool = $RunspacePool
$PSinstance.BeginInvoke()



So I just need to wait for each job to finish and then capture the results of each which is what I am not sure how to do



Edit: Also I had previously tried to do this with jobs but the code actually took longer than the normal scrip



$userName = Read-Host "Enter NTID: "

$time = 0


$dcs = Get-ADDomainController -Filter Name -like "*" | Select -expandproperty name


$scriptbox = Select -Expandproperty lastLogon



foreach($dc in $dcs)start-Job -ScriptBlock $scriptbox -ArgumentList $username,$dc


Get-Job | Wait-Job


Get-Job

$Data = ForEach ($Job in (Get-Job))

Receive-Job $Job

Remove-Job $Job




Foreach ($date in $Data)if($date -gt $time)$time = $date


$dt = [DateTime]::FromFileTime($time)

write-Host $username "last logged on at:" $dt









share|improve this question
























  • Why would you not want to use normal PowerShell job for this?

    – Jim B
    Jun 3 '16 at 12:35











  • Open to suggestions if there is an easier way to do what i'm trying to accomplish. All of my scripts thus far have all been very linear.

    – Bill Lindsay
    Jun 3 '16 at 12:37












  • Take a look at blogs.technet.microsoft.com/heyscriptingguy/2012/12/31/… seems to me that background jobs are what you are looking for

    – Jim B
    Jun 3 '16 at 12:41











  • Gotcha, yeah I had actually tried something along those lines but for some reason it actually takes longer to run than the linear code. Ill edit the original post with that code

    – Bill Lindsay
    Jun 3 '16 at 12:47













3












3








3








Trying to multithread some of my scripts that take a while to run. One example is getting the last login for a user. It checks all of our DC's and then returns the most recent time. We have quite a few and they are global so running sequentially takes a while.



I saw this answer How do I run my PowerShell scripts in parallel without using Jobs?



which got me going in setting up the runspace and running it but I am not sure how to get the data back.



This is what I have so far



$username = Read-Host "Enter the Users ID"
$dcs = Get-ADDomainController -Filter Name -like "*" | Select -expandproperty name
$Code =

Select -Expandproperty lastLogon

$rsPool = [runspacefactory]::CreateRunspacePool(1,8)
$rsPool.Open()
foreach($dc in $dcs)

$PSinstance = [powershell]::Create().AddScript($Code).AddArgument($username).AddArgument($dc)
$PSinstance.RunspacePool = $RunspacePool
$PSinstance.BeginInvoke()



So I just need to wait for each job to finish and then capture the results of each which is what I am not sure how to do



Edit: Also I had previously tried to do this with jobs but the code actually took longer than the normal scrip



$userName = Read-Host "Enter NTID: "

$time = 0


$dcs = Get-ADDomainController -Filter Name -like "*" | Select -expandproperty name


$scriptbox = Select -Expandproperty lastLogon



foreach($dc in $dcs)start-Job -ScriptBlock $scriptbox -ArgumentList $username,$dc


Get-Job | Wait-Job


Get-Job

$Data = ForEach ($Job in (Get-Job))

Receive-Job $Job

Remove-Job $Job




Foreach ($date in $Data)if($date -gt $time)$time = $date


$dt = [DateTime]::FromFileTime($time)

write-Host $username "last logged on at:" $dt









share|improve this question
















Trying to multithread some of my scripts that take a while to run. One example is getting the last login for a user. It checks all of our DC's and then returns the most recent time. We have quite a few and they are global so running sequentially takes a while.



I saw this answer How do I run my PowerShell scripts in parallel without using Jobs?



which got me going in setting up the runspace and running it but I am not sure how to get the data back.



This is what I have so far



$username = Read-Host "Enter the Users ID"
$dcs = Get-ADDomainController -Filter Name -like "*" | Select -expandproperty name
$Code =

Select -Expandproperty lastLogon

$rsPool = [runspacefactory]::CreateRunspacePool(1,8)
$rsPool.Open()
foreach($dc in $dcs)

$PSinstance = [powershell]::Create().AddScript($Code).AddArgument($username).AddArgument($dc)
$PSinstance.RunspacePool = $RunspacePool
$PSinstance.BeginInvoke()



So I just need to wait for each job to finish and then capture the results of each which is what I am not sure how to do



Edit: Also I had previously tried to do this with jobs but the code actually took longer than the normal scrip



$userName = Read-Host "Enter NTID: "

$time = 0


$dcs = Get-ADDomainController -Filter Name -like "*" | Select -expandproperty name


$scriptbox = Select -Expandproperty lastLogon



foreach($dc in $dcs)start-Job -ScriptBlock $scriptbox -ArgumentList $username,$dc


Get-Job | Wait-Job


Get-Job

$Data = ForEach ($Job in (Get-Job))

Receive-Job $Job

Remove-Job $Job




Foreach ($date in $Data)if($date -gt $time)$time = $date


$dt = [DateTime]::FromFileTime($time)

write-Host $username "last logged on at:" $dt






powershell






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Jun 3 '16 at 12:54







Bill Lindsay

















asked Jun 3 '16 at 12:20









Bill LindsayBill Lindsay

164




164












  • Why would you not want to use normal PowerShell job for this?

    – Jim B
    Jun 3 '16 at 12:35











  • Open to suggestions if there is an easier way to do what i'm trying to accomplish. All of my scripts thus far have all been very linear.

    – Bill Lindsay
    Jun 3 '16 at 12:37












  • Take a look at blogs.technet.microsoft.com/heyscriptingguy/2012/12/31/… seems to me that background jobs are what you are looking for

    – Jim B
    Jun 3 '16 at 12:41











  • Gotcha, yeah I had actually tried something along those lines but for some reason it actually takes longer to run than the linear code. Ill edit the original post with that code

    – Bill Lindsay
    Jun 3 '16 at 12:47

















  • Why would you not want to use normal PowerShell job for this?

    – Jim B
    Jun 3 '16 at 12:35











  • Open to suggestions if there is an easier way to do what i'm trying to accomplish. All of my scripts thus far have all been very linear.

    – Bill Lindsay
    Jun 3 '16 at 12:37












  • Take a look at blogs.technet.microsoft.com/heyscriptingguy/2012/12/31/… seems to me that background jobs are what you are looking for

    – Jim B
    Jun 3 '16 at 12:41











  • Gotcha, yeah I had actually tried something along those lines but for some reason it actually takes longer to run than the linear code. Ill edit the original post with that code

    – Bill Lindsay
    Jun 3 '16 at 12:47
















Why would you not want to use normal PowerShell job for this?

– Jim B
Jun 3 '16 at 12:35





Why would you not want to use normal PowerShell job for this?

– Jim B
Jun 3 '16 at 12:35













Open to suggestions if there is an easier way to do what i'm trying to accomplish. All of my scripts thus far have all been very linear.

– Bill Lindsay
Jun 3 '16 at 12:37






Open to suggestions if there is an easier way to do what i'm trying to accomplish. All of my scripts thus far have all been very linear.

– Bill Lindsay
Jun 3 '16 at 12:37














Take a look at blogs.technet.microsoft.com/heyscriptingguy/2012/12/31/… seems to me that background jobs are what you are looking for

– Jim B
Jun 3 '16 at 12:41





Take a look at blogs.technet.microsoft.com/heyscriptingguy/2012/12/31/… seems to me that background jobs are what you are looking for

– Jim B
Jun 3 '16 at 12:41













Gotcha, yeah I had actually tried something along those lines but for some reason it actually takes longer to run than the linear code. Ill edit the original post with that code

– Bill Lindsay
Jun 3 '16 at 12:47





Gotcha, yeah I had actually tried something along those lines but for some reason it actually takes longer to run than the linear code. Ill edit the original post with that code

– Bill Lindsay
Jun 3 '16 at 12:47










1 Answer
1






active

oldest

votes


















2














You're right to use Runspaces instead of the *-Job cmdlets as they are much faster!



I recently posted AsyncTcpScan which leverages Runspaces and is incredibly fast! It can be easily modified to run any scriptblock. Below is what your original script should look like after being integrated.




WARNING: I wasn't able to test the following code. I made some changes to your original script based on my experience working with the Active Directory cmdlets.




# Script to run in each thread.
[System.Management.Automation.ScriptBlock]$ScriptBlock =

$adUser = Get-ADUser -Identity $args[0] -Server $args[1] -Properties lastLogon

$result = New-Object PSObject -Property @ 'User' = $args[0];
'DC' = $args[1];
'LastLogon' = $adUser.LastLogon;

return $result

# End Scriptblock

function Invoke-AsyncJob

[CmdletBinding()]
param(
[parameter(Mandatory=$true)]
[System.String]
# User ID
$Username
)

Import-Module -Name ActiveDirectory

$Results = @()

$AllJobs = New-Object System.Collections.ArrayList

$AllDomainControllers = Get-ADDomainController -Filter "*"

$HostRunspacePool = [System.Management.Automation.Runspaces.RunspaceFactory]::CreateRunspacePool(2,10,$Host)

$HostRunspacePool.Open()

foreach($DomainController in $AllDomainControllers)

$asyncJob = [System.Management.Automation.PowerShell]::Create().AddScript($ScriptBlock).AddParameters($($Username,$($DomainController.Name)))

$asyncJob.RunspacePool = $HostRunspacePool

$asyncJobObj = @ JobHandle = $asyncJob;
AsyncHandle = $asyncJob.BeginInvoke()

$AllJobs.Add($asyncJobObj)

$ProcessingJobs = $true

Do

$CompletedJobs = $AllJobs While ($ProcessingJobs)

$HostRunspacePool.Close()
$HostRunspacePool.Dispose()

return $Results

# End function Invoke-AsyncJob





share|improve this answer























    Your Answer








    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "2"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













    draft saved

    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fserverfault.com%2fquestions%2f780789%2fhow-to-retrieve-data-from-powershell-runspace-job%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    1 Answer
    1






    active

    oldest

    votes








    1 Answer
    1






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    2














    You're right to use Runspaces instead of the *-Job cmdlets as they are much faster!



    I recently posted AsyncTcpScan which leverages Runspaces and is incredibly fast! It can be easily modified to run any scriptblock. Below is what your original script should look like after being integrated.




    WARNING: I wasn't able to test the following code. I made some changes to your original script based on my experience working with the Active Directory cmdlets.




    # Script to run in each thread.
    [System.Management.Automation.ScriptBlock]$ScriptBlock =

    $adUser = Get-ADUser -Identity $args[0] -Server $args[1] -Properties lastLogon

    $result = New-Object PSObject -Property @ 'User' = $args[0];
    'DC' = $args[1];
    'LastLogon' = $adUser.LastLogon;

    return $result

    # End Scriptblock

    function Invoke-AsyncJob

    [CmdletBinding()]
    param(
    [parameter(Mandatory=$true)]
    [System.String]
    # User ID
    $Username
    )

    Import-Module -Name ActiveDirectory

    $Results = @()

    $AllJobs = New-Object System.Collections.ArrayList

    $AllDomainControllers = Get-ADDomainController -Filter "*"

    $HostRunspacePool = [System.Management.Automation.Runspaces.RunspaceFactory]::CreateRunspacePool(2,10,$Host)

    $HostRunspacePool.Open()

    foreach($DomainController in $AllDomainControllers)

    $asyncJob = [System.Management.Automation.PowerShell]::Create().AddScript($ScriptBlock).AddParameters($($Username,$($DomainController.Name)))

    $asyncJob.RunspacePool = $HostRunspacePool

    $asyncJobObj = @ JobHandle = $asyncJob;
    AsyncHandle = $asyncJob.BeginInvoke()

    $AllJobs.Add($asyncJobObj)

    $ProcessingJobs = $true

    Do

    $CompletedJobs = $AllJobs While ($ProcessingJobs)

    $HostRunspacePool.Close()
    $HostRunspacePool.Dispose()

    return $Results

    # End function Invoke-AsyncJob





    share|improve this answer



























      2














      You're right to use Runspaces instead of the *-Job cmdlets as they are much faster!



      I recently posted AsyncTcpScan which leverages Runspaces and is incredibly fast! It can be easily modified to run any scriptblock. Below is what your original script should look like after being integrated.




      WARNING: I wasn't able to test the following code. I made some changes to your original script based on my experience working with the Active Directory cmdlets.




      # Script to run in each thread.
      [System.Management.Automation.ScriptBlock]$ScriptBlock =

      $adUser = Get-ADUser -Identity $args[0] -Server $args[1] -Properties lastLogon

      $result = New-Object PSObject -Property @ 'User' = $args[0];
      'DC' = $args[1];
      'LastLogon' = $adUser.LastLogon;

      return $result

      # End Scriptblock

      function Invoke-AsyncJob

      [CmdletBinding()]
      param(
      [parameter(Mandatory=$true)]
      [System.String]
      # User ID
      $Username
      )

      Import-Module -Name ActiveDirectory

      $Results = @()

      $AllJobs = New-Object System.Collections.ArrayList

      $AllDomainControllers = Get-ADDomainController -Filter "*"

      $HostRunspacePool = [System.Management.Automation.Runspaces.RunspaceFactory]::CreateRunspacePool(2,10,$Host)

      $HostRunspacePool.Open()

      foreach($DomainController in $AllDomainControllers)

      $asyncJob = [System.Management.Automation.PowerShell]::Create().AddScript($ScriptBlock).AddParameters($($Username,$($DomainController.Name)))

      $asyncJob.RunspacePool = $HostRunspacePool

      $asyncJobObj = @ JobHandle = $asyncJob;
      AsyncHandle = $asyncJob.BeginInvoke()

      $AllJobs.Add($asyncJobObj)

      $ProcessingJobs = $true

      Do

      $CompletedJobs = $AllJobs While ($ProcessingJobs)

      $HostRunspacePool.Close()
      $HostRunspacePool.Dispose()

      return $Results

      # End function Invoke-AsyncJob





      share|improve this answer

























        2












        2








        2







        You're right to use Runspaces instead of the *-Job cmdlets as they are much faster!



        I recently posted AsyncTcpScan which leverages Runspaces and is incredibly fast! It can be easily modified to run any scriptblock. Below is what your original script should look like after being integrated.




        WARNING: I wasn't able to test the following code. I made some changes to your original script based on my experience working with the Active Directory cmdlets.




        # Script to run in each thread.
        [System.Management.Automation.ScriptBlock]$ScriptBlock =

        $adUser = Get-ADUser -Identity $args[0] -Server $args[1] -Properties lastLogon

        $result = New-Object PSObject -Property @ 'User' = $args[0];
        'DC' = $args[1];
        'LastLogon' = $adUser.LastLogon;

        return $result

        # End Scriptblock

        function Invoke-AsyncJob

        [CmdletBinding()]
        param(
        [parameter(Mandatory=$true)]
        [System.String]
        # User ID
        $Username
        )

        Import-Module -Name ActiveDirectory

        $Results = @()

        $AllJobs = New-Object System.Collections.ArrayList

        $AllDomainControllers = Get-ADDomainController -Filter "*"

        $HostRunspacePool = [System.Management.Automation.Runspaces.RunspaceFactory]::CreateRunspacePool(2,10,$Host)

        $HostRunspacePool.Open()

        foreach($DomainController in $AllDomainControllers)

        $asyncJob = [System.Management.Automation.PowerShell]::Create().AddScript($ScriptBlock).AddParameters($($Username,$($DomainController.Name)))

        $asyncJob.RunspacePool = $HostRunspacePool

        $asyncJobObj = @ JobHandle = $asyncJob;
        AsyncHandle = $asyncJob.BeginInvoke()

        $AllJobs.Add($asyncJobObj)

        $ProcessingJobs = $true

        Do

        $CompletedJobs = $AllJobs While ($ProcessingJobs)

        $HostRunspacePool.Close()
        $HostRunspacePool.Dispose()

        return $Results

        # End function Invoke-AsyncJob





        share|improve this answer













        You're right to use Runspaces instead of the *-Job cmdlets as they are much faster!



        I recently posted AsyncTcpScan which leverages Runspaces and is incredibly fast! It can be easily modified to run any scriptblock. Below is what your original script should look like after being integrated.




        WARNING: I wasn't able to test the following code. I made some changes to your original script based on my experience working with the Active Directory cmdlets.




        # Script to run in each thread.
        [System.Management.Automation.ScriptBlock]$ScriptBlock =

        $adUser = Get-ADUser -Identity $args[0] -Server $args[1] -Properties lastLogon

        $result = New-Object PSObject -Property @ 'User' = $args[0];
        'DC' = $args[1];
        'LastLogon' = $adUser.LastLogon;

        return $result

        # End Scriptblock

        function Invoke-AsyncJob

        [CmdletBinding()]
        param(
        [parameter(Mandatory=$true)]
        [System.String]
        # User ID
        $Username
        )

        Import-Module -Name ActiveDirectory

        $Results = @()

        $AllJobs = New-Object System.Collections.ArrayList

        $AllDomainControllers = Get-ADDomainController -Filter "*"

        $HostRunspacePool = [System.Management.Automation.Runspaces.RunspaceFactory]::CreateRunspacePool(2,10,$Host)

        $HostRunspacePool.Open()

        foreach($DomainController in $AllDomainControllers)

        $asyncJob = [System.Management.Automation.PowerShell]::Create().AddScript($ScriptBlock).AddParameters($($Username,$($DomainController.Name)))

        $asyncJob.RunspacePool = $HostRunspacePool

        $asyncJobObj = @ JobHandle = $asyncJob;
        AsyncHandle = $asyncJob.BeginInvoke()

        $AllJobs.Add($asyncJobObj)

        $ProcessingJobs = $true

        Do

        $CompletedJobs = $AllJobs While ($ProcessingJobs)

        $HostRunspacePool.Close()
        $HostRunspacePool.Dispose()

        return $Results

        # End function Invoke-AsyncJob






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Apr 25 at 21:32









        phbitsphbits

        314




        314



























            draft saved

            draft discarded
















































            Thanks for contributing an answer to Server Fault!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid


            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.

            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fserverfault.com%2fquestions%2f780789%2fhow-to-retrieve-data-from-powershell-runspace-job%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            I,UN,OVfDofyfhDIzc0yiyU4Q7A,LAhfZERCud V rc8C0UnDKUTu6LFJi,6xoBg
            UXJU1pQljP,wFDsFVlqFlrm3GDKmAU,JZqlIlO aJh,8OU BE6

            Popular posts from this blog

            RemoteApp sporadic failureWindows 2008 RemoteAPP client disconnects within a matter of minutesWhat is the minimum version of RDP supported by Server 2012 RDS?How to configure a Remoteapp server to increase stabilityMicrosoft RemoteApp Active SessionRDWeb TS connection broken for some users post RemoteApp certificate changeRemote Desktop Licensing, RemoteAPPRDS 2012 R2 some users are not able to logon after changed date and time on Connection BrokersWhat happens during Remote Desktop logon, and is there any logging?After installing RDS on WinServer 2016 I still can only connect with two users?RD Connection via RDGW to Session host is not connecting

            Vilaño, A Laracha Índice Patrimonio | Lugares e parroquias | Véxase tamén | Menú de navegación43°14′52″N 8°36′03″O / 43.24775, -8.60070

            Cegueira Índice Epidemioloxía | Deficiencia visual | Tipos de cegueira | Principais causas de cegueira | Tratamento | Técnicas de adaptación e axudas | Vida dos cegos | Primeiros auxilios | Crenzas respecto das persoas cegas | Crenzas das persoas cegas | O neno deficiente visual | Aspectos psicolóxicos da cegueira | Notas | Véxase tamén | Menú de navegación54.054.154.436928256blindnessDicionario da Real Academia GalegaPortal das Palabras"International Standards: Visual Standards — Aspects and Ranges of Vision Loss with Emphasis on Population Surveys.""Visual impairment and blindness""Presentan un plan para previr a cegueira"o orixinalACCDV Associació Catalana de Cecs i Disminuïts Visuals - PMFTrachoma"Effect of gene therapy on visual function in Leber's congenital amaurosis"1844137110.1056/NEJMoa0802268Cans guía - os mellores amigos dos cegosArquivadoEscola de cans guía para cegos en Mortágua, PortugalArquivado"Tecnología para ciegos y deficientes visuales. Recopilación de recursos gratuitos en la Red""Colorino""‘COL.diesis’, escuchar los sonidos del color""COL.diesis: Transforming Colour into Melody and Implementing the Result in a Colour Sensor Device"o orixinal"Sistema de desarrollo de sinestesia color-sonido para invidentes utilizando un protocolo de audio""Enseñanza táctil - geometría y color. Juegos didácticos para niños ciegos y videntes""Sistema Constanz"L'ocupació laboral dels cecs a l'Estat espanyol està pràcticament equiparada a la de les persones amb visió, entrevista amb Pedro ZuritaONCE (Organización Nacional de Cegos de España)Prevención da cegueiraDescrición de deficiencias visuais (Disc@pnet)Braillín, un boneco atractivo para calquera neno, con ou sen discapacidade, que permite familiarizarse co sistema de escritura e lectura brailleAxudas Técnicas36838ID00897494007150-90057129528256DOID:1432HP:0000618D001766C10.597.751.941.162C97109C0155020