Partager via


Wait-Job

Attend qu’un ou tous les travaux PowerShell en cours d’exécution dans la session soient terminées.

Syntaxe

SessionIdParameterSet (Par défaut)

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

JobParameterSet

Wait-Job
    [-Job] <Job[]>
    [-Any]
    [-Timeout <Int32>]
    [-Force]
    [<CommonParameters>]

NameParameterSet

Wait-Job
    [-Name] <String[]>
    [-Any]
    [-Timeout <Int32>]
    [-Force]
    [<CommonParameters>]

InstanceIdParameterSet

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

StateParameterSet

Wait-Job
    [-State] <JobState>
    [-Any]
    [-Timeout <Int32>]
    [-Force]
    [<CommonParameters>]

FilterParameterSet

Wait-Job
    [-Filter] <Hashtable>
    [-Any]
    [-Timeout <Int32>]
    [-Force]
    [<CommonParameters>]

Description

L’applet de commande Wait-Job attend qu’un travail soit dans un état d’arrêt avant de reprendre son exécution. Les états de fin sont les suivants :

  • Terminé
  • Échec
  • Arrêté
  • Interrompu
  • Déconnecté

Vous pouvez attendre qu’un travail spécifié, ou que tous les travaux soient en état d’arrêt. Vous pouvez également définir un délai d'attente maximal pour le travail à l'aide du paramètre Timeout, ou utiliser le paramètre Force pour attendre un travail dans les états Suspended ou Disconnected.

Lorsque les commandes du travail sont terminées, Wait-Job retourne un objet de travail et poursuit l’exécution.

Vous pouvez utiliser l’applet de commande Wait-Job pour attendre les travaux commencés à l’aide de l’applet de commande Start-Job ou du paramètre AsJob de l’applet de commande Invoke-Command. Pour plus d’informations sur les emplois, consultez about_Jobs.

À compter de Windows PowerShell 3.0, l’applet de commande Wait-Job attend également les types de travaux personnalisés, tels que les travaux de flux de travail et les instances de travaux planifiés. Pour permettre à Wait-Job d’attendre des travaux d’un type particulier, importez le module qui prend en charge le type de travail personnalisé dans la session avant d’exécuter l’applet de commande Get-Job, soit à l’aide de l’applet de commande Import-Module, soit en utilisant ou en obtenant une applet de commande dans le module. Pour plus d’informations sur un type de travail personnalisé particulier, consultez la documentation de la fonctionnalité de type de travail personnalisé.

Exemples

Exemple 1 : attendre tous les travaux

Get-Job | Wait-Job

Cette commande attend que tous les travaux en cours d’exécution dans la session se terminent.

Exemple 2 : Attendre que les travaux démarrent sur des ordinateurs distants à l’aide de Start-Job

$s = New-PSSession Server01, Server02, Server03
Invoke-Command -Session $s -ScriptBlock {Start-Job -Name Date1 -ScriptBlock {Get-Date}}
$done = Invoke-Command -Session $s -Command {Wait-Job -Name Date1}
$done.Count
3

Cet exemple montre comment utiliser l’applet de commande Wait-Job avec les travaux démarrés sur des ordinateurs distants à l’aide de l’applet de commande Start-Job. Les commandes Start-Job et Wait-Job sont envoyées à l’ordinateur distant à l’aide de l’applet de commande Invoke-Command.

Cet exemple utilise Wait-Job pour déterminer si une commande Get-Date exécutée en tant que travail sur trois ordinateurs différents est terminée.

La première commande crée une session Windows PowerShell (PSSession) sur chacun des trois ordinateurs distants et les stocke dans la variable $s.

La deuxième commande utilise Invoke-Command pour exécuter Start-Job dans chacune des trois sessions de $s. Tous les travaux sont nommés Date1.

La troisième commande utilise Invoke-Command pour exécuter Wait-Job. Cette commande attend que les tâches Date1 sur chaque ordinateur se terminent. Il stocke la collection résultante (tableau) d’objets tâche dans la variable $done.

La quatrième commande utilise la propriété Count du tableau d’objets de travail dans la variable $done pour déterminer le nombre de travaux terminés.

Exemple 3 : Déterminer quand le premier travail se termine

$s = New-PSSession -ComputerName (Get-Content -Path .\Machines.txt)
$c = 'Get-EventLog -LogName System | Where-Object {$PSItem.EntryType -eq "error" --and $PSItem.Source -eq "LSASRV"} | Out-File -FilePath Errors.txt'
Invoke-Command -Session $s -ScriptBlock {Start-Job -ScriptBlock {$Using:c}
Invoke-Command -Session $s -ScriptBlock {Wait-Job -Any}

Cet exemple utilise le paramètre Any de Wait-Job pour déterminer quand le premier de nombreux travaux en cours d’exécution dans la session en cours est en cours de terminaison. Il montre également comment utiliser l’applet de commande Wait-Job pour attendre que les travaux distants se terminent.

La première commande crée un PSSession sur chacun des ordinateurs répertoriés dans le fichier Machines.txt et stocke les objets PSSession dans la variable $s. La commande utilise l’applet de commande Get-Content pour obtenir le contenu du fichier. La commande Get-Content est placée entre parenthèses pour vous assurer qu’elle s’exécute avant la commande New-PSSession.

La deuxième commande stocke une chaîne de commande Get-EventLog, entre guillemets, dans la variable $c.

La troisième commande utilise Invoke-Command cmdlet pour exécuter Start-Job dans chacune des sessions de $s. La commande Start-Job démarre un travail qui exécute la commande Get-EventLog dans la variable $c.

La commande utilise le modificateur d’étendue Using: pour indiquer que la variable $c a été définie sur l’ordinateur local. Le modificateur d’étendue Using: est introduit dans Windows PowerShell 3.0. Pour plus d’informations sur le modificateur d’étendue Using: , consultez about_Remote_Variables.

La quatrième commande utilise Invoke-Command pour exécuter une commande Wait-Job dans les sessions. Il utilise le paramètre Any pour attendre que le premier travail sur les ordinateurs distants soit en état d’arrêt.

Exemple 4 : Définir un temps d’attente pour les travaux sur des ordinateurs distants

PS> $s = New-PSSession -ComputerName Server01, Server02, Server03
PS> $jobs = Invoke-Command -Session $s -ScriptBlock {Start-Job -ScriptBlock {Get-Date}}
PS> $done = Invoke-Command -Session $s -ScriptBlock {Wait-Job -Timeout 30}
PS>

Cet exemple montre comment utiliser le paramètre Timeout de Wait-Job pour définir un délai d’attente maximal pour les travaux exécutés sur des ordinateurs distants.

La première commande crée une psSession sur chacun des trois ordinateurs distants (Server01, Server02 et Server03), puis stocke les objets PSSession dans la variable $s.

La deuxième commande utilise Invoke-Command pour exécuter Start-Job dans chacun des objets PSSession dans $s. Il stocke les objets de travail résultants dans la variable $jobs.

La troisième commande utilise Invoke-Command pour exécuter Wait-Job dans chacune des sessions de $s. La commande Wait-Job détermine si toutes les commandes ont été effectuées dans les 30 secondes. Il utilise le paramètre Timeout avec la valeur 30 pour établir le délai d’attente maximal, puis stocke les résultats de la commande dans la variable $done.

Dans ce cas, après 30 secondes, seule la commande sur l’ordinateur Server02 est terminée. Wait-Job met fin à l’attente, retourne l’objet qui représente le travail qui s’est terminé et affiche l’invite de commandes.

La variable $done contient un objet de travail qui représente le travail exécuté sur Server02.

Exemple 5 : Patientez jusqu’à la fin de l’un de plusieurs travaux

Wait-Job -Id 1, 2, 5 -Any

Cette commande identifie trois travaux par leurs ID et attend que l’un d’eux soit dans un état d’arrêt. L'exécution continue après que la première tâche est terminée.

Exemple 6 : Attendre une période, puis autoriser le travail à continuer en arrière-plan

Wait-Job -Name "DailyLog" -Timeout 120

Cette commande attend 120 secondes (deux minutes) pour que la tâche DailyLog se termine. Si le travail ne se termine pas au cours des deux prochaines minutes, l’exécution se poursuit et le travail continue à s’exécuter en arrière-plan.

Exemple 7 : attendre un travail par nom

Wait-Job -Name "Job3"

Cette commande utilise le nom du travail pour identifier le travail pour lequel attendre.

Exemple 8 : attendre que les travaux sur l’ordinateur local aient démarré avec Start-Job

$j = Start-Job -ScriptBlock {Get-ChildItem -Filter *.ps1 | Where-Object {$PSItem.LastWriteTime -gt ((Get-Date) - (New-TimeSpan -Days 7))}}
$j | Wait-Job

Cet exemple montre comment utiliser l’applet de commande Wait-Job avec des travaux démarrés sur l’ordinateur local à l’aide de Start-Job.

Ces commandes démarrent un travail qui obtient les fichiers de script Windows PowerShell qui ont été ajoutés ou mis à jour la semaine dernière.

La première commande utilise Start-Job pour démarrer un travail sur l’ordinateur local. Le travail exécute une commande Get-ChildItem qui obtient tous les fichiers qui ont une extension de nom de fichier .ps1 qui ont été ajoutés ou mis à jour la semaine dernière.

La troisième commande utilise Wait-Job pour attendre que le travail soit en état d’arrêt. Une fois le travail terminé, la commande affiche l’objet de travail, qui contient des informations sur le travail.

Exemple 9 : Attendre que les travaux démarrent sur des ordinateurs distants à l’aide de Invoke-Command

$s = New-PSSession -ComputerName Server01, Server02, Server03
$j = Invoke-Command -Session $s -ScriptBlock {Get-Process} -AsJob
$j | Wait-Job

Cet exemple montre comment utiliser Wait-Job avec les travaux démarrés sur des ordinateurs distants à l’aide du paramètre AsJob de Invoke-Command. Lorsque vous utilisez AsJob, le travail est créé sur l’ordinateur local et les résultats sont automatiquement retournés à l’ordinateur local, même si le travail s’exécute sur les ordinateurs distants.

Cet exemple utilise Wait-Job pour déterminer si une commande Get-Process en cours d’exécution dans les sessions sur trois ordinateurs distants est dans un état de fin.

La première commande crée objets PSSession sur trois ordinateurs et les stocke dans la variable $s.

La deuxième commande utilise Invoke-Command pour exécuter Get-Process dans chacune des trois sessions de $s. La commande utilise le paramètre AsJob pour exécuter la commande de manière asynchrone en tant que travail. La commande retourne un objet de travail, tout comme les travaux démarrés à l’aide de Start-Job, et l’objet de travail est stocké dans la variable $j.

La troisième commande utilise un opérateur de pipeline (|) pour envoyer l’objet de travail dans $j à l’applet de commande Wait-Job. Une commande Invoke-Command n’est pas nécessaire dans ce cas, car le travail réside sur l’ordinateur local.

Exemple 10 : attendre un travail qui possède un ID

Get-Job
Id   Name     State      HasMoreData     Location             Command
--   ----     -----      -----------     --------             -------
1    Job1     Completed  True            localhost,Server01.. Get-Service
4    Job4     Completed  True            localhost            dir | where
Wait-Job -Id 1

Cette commande attend la tâche dotée d'un ID de valeur 1.

Paramètres

-Any

Indique que cette applet de commande retourne l’objet de travail et continue l’exécution à la fin d’un travail. Par défaut, Wait-Job attend que tous les travaux spécifiés soient terminés avant d’afficher l’invite.

Propriétés du paramètre

Type:SwitchParameter
Valeur par défaut:None
Prend en charge les caractères génériques:False
DontShow:False

Jeux de paramètres

(All)
Position:Named
Obligatoire:False
Valeur du pipeline:False
Valeur du pipeline par nom de propriété:False
Valeur des arguments restants:False

-Filter

Spécifie une table de hachage de conditions. Cette applet de commande attend des travaux qui répondent à toutes les conditions dans la table de hachage. Entrez une table de hachage où les clés sont les propriétés des travaux et les valeurs celles des propriétés des travaux.

Ce paramètre fonctionne uniquement sur les types de travaux personnalisés, tels que les travaux de flux de travail et les travaux planifiés. Elle ne fonctionne pas sur des travaux standard, tels que ceux créés à l’aide de l’applet de commande Start-Job. Pour plus d’informations sur la prise en charge de ce paramètre, consultez la rubrique d’aide pour le type de travail.

Ce paramètre a été introduit dans Windows PowerShell 3.0.

Propriétés du paramètre

Type:Hashtable
Valeur par défaut:None
Prend en charge les caractères génériques:False
DontShow:False

Jeux de paramètres

FilterParameterSet
Position:0
Obligatoire:True
Valeur du pipeline:False
Valeur du pipeline par nom de propriété:True
Valeur des arguments restants:False

-Force

Indique que cette applet de commande continue d’attendre les travaux dans l’état Suspendu ou Déconnecté. Par défaut, Wait-Job retourne, ou met fin à l’attente, lorsque les travaux se trouvent dans l’un des états suivants :

  • Terminé
  • Échec
  • Arrêté
  • Interrompu
  • Déconnecté

Ce paramètre a été introduit dans Windows PowerShell 3.0.

Propriétés du paramètre

Type:SwitchParameter
Valeur par défaut:None
Prend en charge les caractères génériques:False
DontShow:False

Jeux de paramètres

(All)
Position:Named
Obligatoire:False
Valeur du pipeline:False
Valeur du pipeline par nom de propriété:False
Valeur des arguments restants:False

-Id

Spécifie un tableau d’ID de travaux pour lesquels cette applet de commande attend.

L’ID est un entier qui identifie de façon unique la tâche dans la session actuelle. Il est plus facile de mémoriser et de taper que l’ID d’instance, mais il est unique uniquement dans la session active. Vous pouvez taper un ou plusieurs ID, séparés par des virgules. Pour rechercher l’ID d’un travail, tapez Get-Job.

Propriétés du paramètre

Type:

Int32[]

Valeur par défaut:None
Prend en charge les caractères génériques:False
DontShow:False

Jeux de paramètres

SessionIdParameterSet
Position:0
Obligatoire:True
Valeur du pipeline:False
Valeur du pipeline par nom de propriété:True
Valeur des arguments restants:False

-InstanceId

Spécifie un tableau d’ID d’instances de travaux pour lesquels cette applet de commande attend. Par défaut, il s'agit de toutes les tâches.

Un ID d’instance est un GUID qui identifie de façon unique le travail sur l’ordinateur. Pour rechercher l’ID d’instance d’un travail, utilisez Get-Job.

Propriétés du paramètre

Type:

Guid[]

Valeur par défaut:None
Prend en charge les caractères génériques:False
DontShow:False

Jeux de paramètres

InstanceIdParameterSet
Position:0
Obligatoire:True
Valeur du pipeline:False
Valeur du pipeline par nom de propriété:True
Valeur des arguments restants:False

-Job

Spécifie les travaux pour lesquels cette applet de commande attend. Entrez une variable qui contient les objets de travail ou une commande qui obtient les objets de travail. Vous pouvez également utiliser un opérateur de pipeline pour envoyer des objets de travail à l’applet de commande Wait-Job. Par défaut, Wait-Job attend tous les travaux créés dans la session en cours.

Propriétés du paramètre

Type:

Job[]

Valeur par défaut:None
Prend en charge les caractères génériques:False
DontShow:False

Jeux de paramètres

JobParameterSet
Position:0
Obligatoire:True
Valeur du pipeline:True
Valeur du pipeline par nom de propriété:True
Valeur des arguments restants:False

-Name

Spécifie les noms conviviaux des travaux pour lesquels cette applet de commande attend.

Propriétés du paramètre

Type:

String[]

Valeur par défaut:None
Prend en charge les caractères génériques:False
DontShow:False

Jeux de paramètres

NameParameterSet
Position:0
Obligatoire:True
Valeur du pipeline:False
Valeur du pipeline par nom de propriété:True
Valeur des arguments restants:False

-State

Spécifie un état de travail. Cette applet de commande attend uniquement les travaux dans l’état spécifié. Les valeurs acceptables pour ce paramètre sont les suivantes :

  • NotStarted
  • Course à pied
  • Terminé
  • Échec
  • Arrêté
  • Bloqué
  • Interrompu
  • Déconnecté
  • Suspension
  • Arrêt

Pour plus d’informations sur les états des travaux, consultez l’énumération JobState.

Propriétés du paramètre

Type:JobState
Valeur par défaut:None
Valeurs acceptées:NotStarted, Running, Completed, Failed, Stopped, Blocked, Suspended, Disconnected, Suspending, Stopping, AtBreakpoint
Prend en charge les caractères génériques:False
DontShow:False

Jeux de paramètres

StateParameterSet
Position:0
Obligatoire:True
Valeur du pipeline:False
Valeur du pipeline par nom de propriété:True
Valeur des arguments restants:False

-Timeout

Spécifie le temps d’attente maximal pour chaque travail, en secondes. La valeur par défaut, -1, indique que l’applet de commande attend la fin du travail. Le minutage commence lorsque vous envoyez la commande Wait-Job, et non la commande Start-Job.

Si cette durée est dépassée, l’attente se termine et l’exécution se poursuit, même si le travail est toujours en cours d’exécution. La commande n’affiche aucun message d’erreur.

Propriétés du paramètre

Type:Int32
Valeur par défaut:None
Prend en charge les caractères génériques:False
DontShow:False
Alias:TimeoutSec

Jeux de paramètres

(All)
Position:Named
Obligatoire:False
Valeur du pipeline:False
Valeur du pipeline par nom de propriété:False
Valeur des arguments restants:False

CommonParameters

Cette applet de commande prend en charge les paramètres courants : -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutBuffer, -OutVariable, -PipelineVariable, -ProgressAction, -Verbose, -WarningAction et -WarningVariable. Pour plus d’informations, consultez about_CommonParameters.

Entrées

System.Management.Automation.RemotingJob

Vous pouvez diriger un objet de travail vers cette applet de commande.

Sorties

System.Management.Automation.PSRemotingJob

Cette applet de commande retourne des objets de travail qui représentent les travaux dans un état d’arrêt. Si l’attente se termine parce que la valeur du paramètre de délai d’attente est dépassée, Wait-Job ne retourne aucun objet.

Notes

PowerShell inclut les alias suivants pour Wait-Job:

  • Toutes les plateformes :
    • wjb

Par défaut, Wait-Job retourne, ou met fin à l’attente, lorsque les travaux se trouvent dans l’un des états suivants :

  • Terminé
  • Échec
  • Arrêté
  • Interrompu
  • Déconnecté

Pour diriger Wait-Job pour continuer à attendre les travaux suspendus et déconnectés, utilisez le paramètre Force.