다음을 통해 공유


Wait-Job

해당 세션에서 실행되는 Windows PowerShell 백그라운드 작업 중 하나나 전부가 완료될 때까지 명령 프롬프트를 표시하지 않습니다.

구문

Wait-Job [[-InstanceId] <Guid[]>] [-Any] [-Timeout <int>] [<CommonParameters>]

Wait-Job [-Job] <Job[]> [-Any] [-Timeout <int>] [<CommonParameters>]

Wait-Job [[-Name] <string[]>] [-Any] [-Timeout <int>] [<CommonParameters>]

Wait-Job [-Id] <Int32[]> [-Any] [-Timeout <int>] [<CommonParameters>]

Wait-Job [-State {<NotStarted> | <Running> | <Completed> | <Failed> | <Stopped> | <Blocked>}] [-Any] [-Timeout <int>] [<CommonParameters>]

설명

Wait-Job cmdlet은 명령 프롬프트를 표시하기 전에 Windows PowerShell 백그라운드 작업이 완료될 때까지 기다립니다. 백그라운드 작업 중 하나가 완료되거나 모든 백그라운드 작업이 완료될 때까지 기다릴 수 있으며 작업의 최대 대기 시간을 설정할 수 있습니다.

Wait-Job을 사용하여 Start-Job을 통해서나 Invoke-Command의 AsJob 매개 변수를 통해 시작된 백그라운드 작업을 가져올 수 있습니다.

작업의 명령이 완료되면 Wait-Job은 명령 프롬프트를 표시하고 다른 명령으로 파이프할 수 있도록 작업 개체를 반환합니다.

매개 변수

-Any

작업이 완료될 때마다 작업 개체를 반환하고 명령 프롬프트를 표시합니다. 기본적으로 Wait-Job은 지정된 모든 작업이 완료되기까지 기다렸다가 프롬프트를 표시합니다.

필수 여부

false

위치

named

기본값

파이프라인 입력 적용 여부

false

와일드카드 문자 적용 여부

false

-Id <Int32[]>

지정된 ID를 가진 작업이 완료될 때까지 기다립니다.

ID는 현재 세션 내에서 작업을 고유하게 식별하는 정수입니다. 이 ID는 InstanceId보다 기억하거나 입력하기 쉽지만 현재 세션 내부에서만 고유합니다. 쉼표로 구분하여 하나 이상의 ID를 입력할 수 있습니다. 작업 ID를 찾으려면 매개 변수 없이 "Get-Job"을 입력합니다.

필수 여부

true

위치

1

기본값

파이프라인 입력 적용 여부

true (ByPropertyName)

와일드카드 문자 적용 여부

false

-InstanceId <Guid[]>

지정된 인스턴스 ID를 가진 작업이 완료될 때까지 기다립니다. 기본값은 모든 작업입니다.

인스턴스 ID는 컴퓨터의 작업을 고유하게 식별하는 GUID입니다. 작업의 인스턴스 ID를 찾으려면 Get-Job을 사용합니다.

필수 여부

false

위치

1

기본값

파이프라인 입력 적용 여부

true (ByPropertyName)

와일드카드 문자 적용 여부

false

-Job <Job[]>

지정된 작업이 완료될 때까지 기다립니다. 작업 개체가 포함된 변수나 작업 개체를 가져오는 명령을 입력하십시오. 또한 파이프라인 연산자를 사용하여 작업 개체를 Wait-Job cmdlet으로 보낼 수 있습니다. 기본적으로 Wait-Job은 현재 세션에서 만들어진 모든 작업이 완료될 때까지 기다립니다.

필수 여부

true

위치

1

기본값

파이프라인 입력 적용 여부

true (ByValue, ByPropertyName)

와일드카드 문자 적용 여부

false

-Name <string[]>

지정된 이름의 작업이 완료될 때까지 기다립니다.

필수 여부

false

위치

1

기본값

파이프라인 입력 적용 여부

true (ByPropertyName)

와일드카드 문자 적용 여부

false

-State <JobState>

지정된 상태의 작업이 완료될 때까지 기다립니다. 유효한 값은 NotStarted, Running, Completed, Stopped, Failed 및 Blocked입니다.

필수 여부

false

위치

named

기본값

파이프라인 입력 적용 여부

true (ByPropertyName)

와일드카드 문자 적용 여부

false

-Timeout <int>

각 백그라운드 작업에 대한 최대 대기 시간을 초 단위로 결정합니다. 기본값인 -1의 경우 작업이 얼마나 오래 실행되는지에 관계없이 작업이 완료될 때까지 대기합니다. 타이밍은 Start-Job 명령을 전송할 때가 아니라 Wait-Job 명령을 전송할 때 시작됩니다.

이 시간이 초과되면 작업이 여전히 실행 중인 경우에도 대기가 종료되고 명령 프롬프트가 반환됩니다. 오류 메시지가 표시되지 않습니다.

필수 여부

false

위치

named

기본값

파이프라인 입력 적용 여부

false

와일드카드 문자 적용 여부

false

<CommonParameters>

이 cmdlet은 -Verbose, -Debug, -ErrorAction, -ErrorVariable, -OutBuffer, -OutVariable 등의 일반 매개 변수를 지원합니다. 자세한 내용은 about_commonparameters.

입력 및 출력

입력 유형은 cmdlet으로 파이프할 수 있는 개체의 유형입니다. 반환 유형은 cmdlet에서 반환되는 개체의 유형입니다.

입력

System.Management.Automation.RemotingJob

작업 개체를 Wait-Job으로 파이프할 수 있습니다.

출력

System.Management.Automation.RemotingJob

Wait-Job은 완료된 작업을 나타내는 작업 개체를 반환합니다. Timeout 매개 변수의 값이 초과되어 대기가 종료되는 경우 Wait-Job은 개체를 반환하지 않습니다.

예 1

C:\PS>get-job | wait-job

설명
-----------
이 명령은 해당 세션에서 실행되는 모든 백그라운드 작업이 완료될 때까지 기다립니다.





예 2

C:\PS>$s = new-pssession server01, server02, server03

C:\PS> invoke-command -session $s -scriptblock {start-job -name Date1 -scriptblock {get-date}}

C:\PS> $done = invoke-command -session $s -command {wait-job -name Date1}

C:\PS> $done.count
3

설명
-----------
이 예에서는 Start-Job cmdlet을 사용하여 원격 컴퓨터에서 시작된 작업에 대해 Wait-Job cmdlet을 사용하는 방법을 보여 줍니다. Start-Job 및 Wait-Job 명령이 Invoke-Command cmdlet을 사용하여 원격 컴퓨터로 전송됩니다.

이 예에서는 Wait-Job을 사용하여 세 컴퓨터에서 백그라운드 작업으로 실행되는 Get-Date 명령이 완료되었는지 여부를 확인합니다. 

첫 번째 명령은 세 원격 컴퓨터에서 각각 Windows PowerShell 세션(PSSession)을 만든 다음 $s 변수에 저장합니다. 

두 번째 명령은 Invoke-Command cmdlet을 사용하여 $s의 세 세션에서 각각 Start-Job 명령을 실행합니다. 모든 작업의 이름은 Date1로 지정됩니다.

세 번째 명령은 Invoke-Command cmdlet을 사용하여 Wait-Job 명령을 실행합니다. 이 명령은 각 컴퓨터에서 Date1 작업이 완료될 때까지 기다린 다음 작업 개체로 이루어진 결과 컬렉션(배열)을 $done 변수에 저장합니다. 

네 번째 명령은 $done 변수에 있는 작업 개체 배열의 Count 속성을 사용하여 완료된 작업 수를 확인합니다.





예 3

C:\PS>$s = new-pssession (get-content machines.txt)  

C:\PS> $c = 'get-eventlog -log system | where {$_.EntryType -eq "error" -and $_.Source -eq "LSASRV"} | out-file errors.txt'

C:\PS> invoke-command -session $s -scriptblock {param($c)start-job -scriptblock {$c}} -ArgumentList $c

C:\PS> invoke-command -session $s -scriptblock {wait-job -any}

설명
-----------
이 예에서는 Wait-Job의 Any 매개 변수를 사용하여 현재 세션에서 실행되는 많은 백그라운드 작업 중 첫 번째 작업이 완료되었는지 확인합니다. 또한 Wait-Job cmdlet을 사용하여 원격 작업이 완료될 때까지 기다리는 방법을 보여 줍니다. 

첫 번째 명령은 Machines.txt 파일에 나열된 각 컴퓨터에 PSSession을 만든 다음 $s 변수에 저장합니다. 이 명령은 Get-Content cmdlet을 사용하여 파일의 내용을 가져옵니다. Get-Content 명령은 New-PSSession 명령 전에 실행되기 위해 괄호로 묶입니다.

두 번째 명령은 Get-EventLog 명령 문자열(따옴표로 묶임)을 $c 변수에 저장합니다.

세 번째 명령은 Invoke-Command cmdlet을 사용하여 $s의 각 세션에서 Start-Job 명령을 실행합니다. Start-Job 명령은 $c의 명령을 실행하는 백그라운드 작업을 시작합니다. 

$c 변수가 로컬 컴퓨터에 있기 때문에 이 명령은 "param" 키워드를 사용하여 명령에서 로컬 변수를 선언하고 ArgumentList 매개 변수를 사용하여 해당 변수의 값을 제공합니다.

네 번째 명령은 Invoke-Command cmdlet을 사용하여 세션에서 Wait-Job 명령을 실행합니다. 또한 Wait-Job cmdlet을 사용하여 원격 컴퓨터의 첫 번째 작업이 완료될 때까지 기다립니다.





예 4

C:\PS>$s = new-pssession Server01, Server02, Server03 

C:\PS> $jobs = invoke-command -session $s -scriptblock {start-job -script {get-date}}

C:\PS> $done = invoke-command -session $s -scriptblock {wait-job -timeout 30}

설명
-----------
이 예에서는 Wait-Job의 Timeout 매개 변수를 사용하여 원격 컴퓨터에서 실행되는 작업의 최대 대기 시간을 설정하는 방법을 보여 줍니다. 

첫 번째 명령은 세 원격 컴퓨터(Server01, Server02 및 Server03)에서 각각 PSSession을 만든 다음 $s 변수에 저장합니다. 

두 번째 명령은 Invoke-Command cmdlet을 사용하여 $s의 각 PSSession에서 Start-Job 명령을 실행합니다. 그런 다음 결과 작업 개체를 $jobs 변수에 저장합니다.

세 번째 명령은 Invoke-Command cmdlet을 사용하여 $s의 각 PSSession에서 Wait-Job 명령을 실행합니다. Wait-Job 명령은 모든 명령이 30초 내에 완료되는지 여부를 결정합니다. 이 명령은 값이 30(초)인 Timeout 매개 변수를 사용하여 최대 대기 시간을 설정하고 명령의 결과를 $done 변수에 저장합니다. 

이 경우 30초 후에 Server02 컴퓨터의 명령만 완료됩니다. Wait-Job은 대기를 종료하고 명령 프롬프트를 표시한 다음 완료된 작업을 나타내는 개체를 반환합니다. 

$done 변수에는 Server02에서 실행된 작업을 나타내는 작업 개체가 포함됩니다.





예 5

C:\PS>wait-job -id 1,2,5 -any

설명
-----------
이 명령은 작업의 ID로 세 작업을 식별하고 그 중 하나가 완료될 때까지 기다립니다. 첫 번째 작업이 완료될 때 명령 프롬프트가 반환됩니다.





예 6

C:\PS>wait-job -name DailyLog -timeout 120

설명
-----------
이 명령은 DailyLog 작업이 완료될 때까지 120초(2분) 동안 기다립니다. 작업이 다음 2분 안에 완료되지 않으면 명령 프롬프트가 반환되고 해당 작업이 백그라운드에서 계속 실행됩니다.





예 7

C:\PS>wait-job -name Job3

설명
-----------
이 Wait-Job 명령은 작업 이름을 사용하여 기다릴 작업을 식별합니다.





예 8

C:\PS>C:\PS> $j = start-job -script {get-childitem *.ps1| where {$_lastwritetime -gt ((get-date) - (new-timespan -days 7))}}

C:\PS> $j | wait-job

설명
-----------
이 예에서는 Start-Job cmdlet을 사용하여 로컬 컴퓨터에서 시작된 작업에 대해 Wait-Job cmdlet을 사용하는 방법을 보여 줍니다.

이들 명령은 지난 주에 추가되었거나 업데이트된 Windows PowerShell 스크립트 파일을 가져오는 작업을 시작합니다.

첫 번째 명령은 Start-Job cmdlet을 사용하여 로컬 컴퓨터에서 백그라운드 작업을 시작합니다. 이 작업은 지난 주에 추가되었거나 업데이트된, 파일 이름 확장명이 ".ps1"인 파일을 모두 가져오는 Get-ChildItem 명령을 실행합니다.

세 번째 명령은 Wait-Job cmdlet을 사용하여 작업이 완료될 때까지 기다립니다. 작업이 완료되면 이 명령은 작업에 대한 정보가 포함된 작업 개체를 표시합니다.





예 9

C:\PS>$s = new-pssession Server01, Server02, Server03

C:\PS> $j = invoke-command -session $s -scriptblock {get-process} -asjob

C:\PS> $j | wait-job

설명
-----------
이 예에서는 Invoke-Command cmdlet의 AsJob 매개 변수를 사용하여 원격 컴퓨터에서 시작된 작업에 대해 Wait-Job cmdlet을 사용하는 방법을 보여 줍니다. AsJob을 사용하면 작업이 원격 컴퓨터에서 실행되는 경우에도 작업이 로컬 컴퓨터에 만들어지고 결과가 로컬 컴퓨터에 자동으로 반환됩니다.

이 예에서는 Wait-Job을 사용하여 세 원격 컴퓨터의 세션에서 실행되는 Get-Process 명령이 완료되었는지 여부를 확인합니다. 

첫 번째 명령은 세 컴퓨터에 PSSession을 만든 다음 $s 변수에 저장합니다. 

두 번째 명령은 Invoke-Command cmdlet을 사용하여 $s의 세 PSSession에서 각각 Get-Process 명령을 실행합니다. 이 명령은 AsJob 매개 변수를 사용하여 명령을 백그라운드 작업으로 비동기 실행합니다. 이 명령은 Start-Job을 사용하여 시작된 작업과 같은 작업 개체를 반환하며, 이 작업 개체는 $j 변수에 저장됩니다.

세 번째 명령은 파이프라인 연산자(|)를 사용하여 $j의 작업 개체를 Wait-Job cmdlet으로 보냅니다. 작업이 로컬 컴퓨터에 있기 때문에 Invoke-Command 명령은 이 경우에 필요하지 않습니다.





예 10

C:\PS>get-job

Id   Name     State      HasMoreData     Location             Command
--   ----     -----      -----------     --------             -------
1    Job1     Completed  True            localhost,server01.. get-service
4    Job4     Completed  True            localhost            dir | where

C:\PS> wait-job -id 1

설명
-----------
이 명령은 ID 값이 1인 작업이 완료될 때까지 기다립니다.





참고 항목

개념

about_Jobs
about_Job_Details
about_remote_jobs
Start-Job
Get-Job
Receive-Job
Stop-Job
Remove-Job
Invoke-Command