about_Jobs

Kort beskrivning

Innehåller information om hur PowerShell-bakgrundsjobb kör ett kommando eller uttryck i bakgrunden utan att interagera med den aktuella sessionen.

Lång beskrivning

PowerShell kör samtidigt kommandon och skript via jobb. Det finns tre jobbtyper som tillhandahålls av PowerShell för att stödja samtidighet.

  • RemoteJob – Kommandon och skript körs på en fjärrsession. Mer information finns i about_Remote_Jobs.
  • BackgroundJob – Kommandon och skript körs i en separat process på den lokala datorn.
  • PSTaskJob eller ThreadJob – Kommandon och skript körs i en separat tråd i samma process på den lokala datorn. Mer information finns i about_Thread_Jobs.

Att köra skript via fjärranslutning, på en separat dator eller i en separat process, ger bra isolering. Eventuella fel som uppstår i fjärrjobbet påverkar inte andra jobb som körs eller den överordnade sessionen som startade jobbet. Dock lägger fjärrkommunikationsskiktet till omkostnader, inklusive objektserialisering. Alla objekt serialiseras och deserialiseras när de skickas mellan den överordnade sessionen och fjärrsessionen (jobbet). Serialisering av stora komplexa dataobjekt kan förbruka stora mängder beräknings- och minnesresurser och överföra stora mängder data i nätverket.

Trådbaserade jobb är inte lika robusta som fjärr- och bakgrundsjobb, eftersom de körs i samma process på olika trådar. Om ett jobb har ett kritiskt fel som kraschar processen avslutas alla andra jobb i processen.

Trådbaserade jobb kräver dock mindre omkostnader. De använder inte fjärrkommunikationsskiktet eller serialiseringen. Resultatobjekten returneras som referenser till levande objekt i den aktuella sessionen. Utan den här kostnaden körs trådbaserade jobb snabbare och använder färre resurser än de andra jobbtyperna.

Viktigt!

Den överordnade sessionen som skapade jobbet övervakar också jobbstatusen och samlar in pipelinedata. Den underordnade jobbprocessen avslutas av den överordnade processen när jobbet når ett slutfört tillstånd. Om den överordnade sessionen avslutas avslutas alla underordnade jobb som körs tillsammans med deras underordnade processer.

Det finns två sätt att kringgå den här situationen:

  1. Använd Invoke-Command för att skapa jobb som körs i frånkopplade sessioner. Mer information finns i about_Remote_Jobs.
  2. Använd Start-Process för att skapa en ny process i stället för ett jobb. Mer information finns i Startprocess.

Jobbets cmdletar

  • Start-Job – Startar ett bakgrundsjobb på en lokal dator.
  • Get-Job – Hämtar bakgrundsjobben som startades i den aktuella sessionen.
  • Receive-Job - Hämtar resultatet av bakgrundsjobb.
  • Stop-Job - Stoppar ett bakgrundsjobb.
  • Wait-Job – Undertrycker kommandotolken tills ett eller alla jobb har slutförts.
  • Remove-Job – Tar bort ett bakgrundsjobb.
  • Invoke-Command – Parametern AsJob skapar ett bakgrundsjobb på en fjärrdator. Du kan använda Invoke-Command för att fjärrköra valfritt jobbkommando, inklusive Start-Job.

Så här startar du ett jobb på den lokala datorn

Om du vill starta ett bakgrundsjobb på den lokala datorn använder du cmdleten Start-Job .

Om du vill skriva ett Start-Job kommando omger du kommandot som jobbet körs i klammerparenteser ({}). Använd parametern ScriptBlock för att ange kommandot.

Följande kommando startar ett bakgrundsjobb som kör ett Get-Process kommando på den lokala datorn.

Start-Job -ScriptBlock {Get-Process}

När du startar ett bakgrundsjobb returnerar kommandotolken omedelbart, även om jobbet tar längre tid att slutföra. Du kan fortsätta att arbeta i sessionen utan avbrott medan jobbet körs.

Kommandot Start-Job returnerar ett objekt som representerar jobbet. Jobbobjektet innehåller användbar information om jobbet, men det innehåller inte jobbresultatet.

Du kan spara jobbobjektet i en variabel och sedan använda det med de andra jobb-cmdletarna för att hantera bakgrundsjobbet. Följande kommando startar ett jobbobjekt och sparar det resulterande jobbobjektet i variabeln $job .

$job = Start-Job -ScriptBlock {Get-Process}

Från och med PowerShell 6.0 kan du använda bakgrundsoperatorn (&) i slutet av en pipeline för att starta ett bakgrundsjobb. Mer information finns i bakgrundsoperatorn.

Att använda bakgrundsoperatorn är funktionellt likvärdigt med att använda cmdleten Start-Job i föregående exempel.

$job = Get-Process &

Hämta jobbobjekt

Cmdleten Get-Job returnerar objekt som representerar bakgrundsjobben som startades i den aktuella sessionen. Utan parametrar Get-Job returnerar alla jobb som startades i den aktuella sessionen.

Get-Job

Jobbobjektet innehåller jobbets tillstånd, vilket anger om jobbet har slutförts. Ett slutfört jobb har tillståndet Slutfört eller Misslyckat. Ett jobb kan också vara Blockerat eller Körs.

Id  Name  PSJobTypeName State      HasMoreData  Location   Command
--  ----  ------------- -----      -----------  --------   -------
1   Job1  BackgroundJob Complete   True         localhost  Get-Process

Du kan spara jobbobjektet i en variabel och använda det för att representera jobbet i ett senare kommando. Följande kommando hämtar jobbet med ID 1 och sparar det i variabeln $job .

$job = Get-Job -Id 1

Hämta resultatet av ett jobb

När du kör ett bakgrundsjobb visas inte resultatet omedelbart. Använd cmdleten för Receive-Job att hämta resultatet av ett bakgrundsjobb.

I följande exempel Receive-Job hämtar cmdleten resultatet av jobbet med hjälp av jobbobjektet i variabeln $job .

Receive-Job -Job $job
Handles  NPM(K)    PM(K)      WS(K) VM(M)   CPU(s)    Id ProcessName
-------  ------    -----      ----- -----   ------    -- -----------
    103       4    11328       9692    56           1176 audiodg
    804      14    12228      14108   100   101.74  1740 CcmExec
    668       7     2672       6168   104    32.26   488 csrss
...

Du kan spara resultatet av ett jobb i en variabel. Följande kommando sparar resultatet av jobbet i variabeln $job till variabeln $results .

$results = Receive-Job -Job $job

Hämta och behålla resultat för partiella jobb

Cmdleten Receive-Job hämtar resultatet av ett bakgrundsjobb. Om jobbet är klart Receive-Job hämtar du alla jobbresultat. Om jobbet fortfarande körs Receive-Job hämtar du de resultat som har genererats hittills. Du kan köra Receive-Job kommandon igen för att få återstående resultat.

Som standard Receive-Job tar bort resultatet från cachen där jobbresultat lagras. När du kör Receive-Job igen får du bara de nya resultat som kom efter den första körningen.

Följande kommandon visar resultatet av Receive-Job kommandon som körs innan jobbet har slutförts.

C:\PS> Receive-Job -Job $job

Handles  NPM(K)    PM(K)      WS(K) VM(M)   CPU(s)     Id ProcessName
-------  ------    -----      ----- -----   ------     -- -----------
    103       4    11328       9692    56            1176 audiodg
    804      14    12228      14108   100   101.74   1740 CcmExec

C:\PS> Receive-Job -Job $job

Handles  NPM(K)    PM(K)      WS(K) VM(M)   CPU(s)     Id ProcessName
-------  ------    -----      ----- -----   ------     -- -----------
    68       3     2632        664    29     0.36   1388 ccmsetup
   749      22    21468      19940   203   122.13   3644 communicator
   905       7     2980       2628    34   197.97    424 csrss
  1121      25    28408      32940   174   430.14   3048 explorer

Använd parametern Behåll för att förhindra Receive-Job att jobbresultaten som returneras tas bort. Följande kommandon visar effekten av att använda parametern Behåll på ett jobb som ännu inte har slutförts.

C:\PS> Receive-Job -Job $job -Keep

Handles  NPM(K)    PM(K)      WS(K) VM(M)   CPU(s)     Id ProcessName
-------  ------    -----      ----- -----   ------     -- -----------
    103       4    11328       9692    56            1176 audiodg
    804      14    12228      14108   100   101.74   1740 CcmExec

C:\PS> Receive-Job -Job $job -Keep

Handles  NPM(K)    PM(K)      WS(K) VM(M)   CPU(s)     Id ProcessName
-------  ------    -----      ----- -----   ------     -- -----------
    103       4    11328       9692    56            1176 audiodg
    804      14    12228      14108   100   101.74   1740 CcmExec
     68       3     2632        664    29     0.36   1388 ccmsetup
    749      22    21468      19940   203   122.13   3644 communicator
    905       7     2980       2628    34   197.97    424 csrss
   1121      25    28408      32940   174   430.14   3048 explorer

Väntar på resultatet

Om du kör ett kommando som tar lång tid att slutföra kan du använda egenskaperna för jobbobjektet för att avgöra när jobbet är klart. Följande kommando använder objektet Get-Job för att hämta alla bakgrundsjobb i den aktuella sessionen.

Get-Job

Resultatet visas i en tabell. Jobbets status visas i kolumnen Tillstånd .

Id Name  PSJobTypeName State    HasMoreData Location  Command
-- ----  ------------- -----    ----------- --------  -------
1  Job1  BackgroundJob Complete True        localhost Get-Process
2  Job2  BackgroundJob Running  True        localhost Get-EventLog -Log ...
3  Job3  BackgroundJob Complete True        localhost dir -Path C:\* -Re...

I det här fallet visar egenskapen State att jobb 2 fortfarande körs. Om du skulle använda cmdleten Receive-Job för att hämta jobbresultatet nu skulle resultatet vara ofullständigt. Du kan använda cmdleten Receive-Job upprepade gånger för att få alla resultat. Använd egenskapen State för att avgöra när jobbet är klart.

Du kan också använda parametern Wait för cmdleten Receive-Job . När du använder den här parametern returnerar cmdleten inte kommandotolken förrän jobbet har slutförts och alla resultat är tillgängliga.

Du kan också använda cmdleten Wait-Job för att vänta på något eller alla resultat av jobbet. Wait-Job låter dig vänta på ett eller flera specifika jobb eller för alla jobb. Följande kommando använder cmdleten Wait-Job för att vänta på ett jobb med ID 10.

Wait-Job -ID 10

Därför ignoreras PowerShell-prompten tills jobbet har slutförts.

Du kan också vänta på en fördefinierad tidsperiod. Det här kommandot använder timeout-parametern för att begränsa väntetiden till 120 sekunder. När tiden går ut returnerar kommandotolken, men jobbet fortsätter att köras i bakgrunden.

Wait-Job -ID 10 -Timeout 120

Stoppa ett jobb

Om du vill stoppa ett bakgrundsjobb använder du cmdleten Stop-Job . Följande kommando startar ett jobb för att hämta varje post i systemhändelseloggen. Det sparar jobbobjektet i variabeln $job .

$job = Start-Job -ScriptBlock {Get-EventLog -Log System}

Följande kommando stoppar jobbet. Den använder en pipelineoperator (|) för att skicka jobbet i variabeln $job till Stop-Job.

$job | Stop-Job

Ta bort ett jobb

Om du vill ta bort ett bakgrundsjobb använder du cmdleten Remove-Job . Följande kommando tar bort jobbet i variabeln $job .

Remove-Job -Job $job

Undersöka ett misslyckat jobb

Jobb kan misslyckas av många orsaker. jobbobjektet innehåller en reason-egenskap som innehåller information om orsaken till felet.

I följande exempel startas ett jobb utan nödvändiga autentiseringsuppgifter.

$job = Start-Job -ScriptBlock {New-Item -Path HKLM:\Software\MyCompany}
Get-Job $job

Id Name  PSJobTypeName State  HasMoreData  Location  Command
-- ----  ------------- -----  -----------  --------  -------
1  Job1  BackgroundJob Failed False        localhost New-Item -Path HKLM:...

Granska egenskapen Reason (Orsak) för att hitta felet som orsakade att jobbet misslyckades.

$job.ChildJobs[0].JobStateInfo.Reason

I det här fallet misslyckades jobbet eftersom fjärrdatorn krävde explicita autentiseringsuppgifter för att köra kommandot. Egenskapen Reason innehåller följande meddelande:

Anslut ing till fjärrservern misslyckades med följande felmeddelande: "Åtkomst nekas".

Se även