Compartilhar via


Sobre a solução de problemas de trabalhos agendados

Descrição breve

Explica como resolve problemas com trabalhos agendados

Descrição longa

Este documento descreve alguns dos problemas que você pode enfrentar ao usar os recursos de trabalho agendados do PowerShell e sugere soluções para esses problemas.

Antes de usar trabalhos agendados do PowerShell, consulte about_Scheduled_Jobs e os trabalhos agendados relacionados sobre tópicos.

Não é possível encontrar os resultados do trabalho

Método básico para obter resultados de trabalho no PowerShell

Quando um trabalho agendado é executado, ele cria uma instância do trabalho agendado. Para exibir, gerenciar e obter os resultados das instâncias de trabalho agendadas, use os cmdlets job.

Observação

Para usar os cmdlets job em instâncias de trabalhos agendados, o módulo PSScheduledJob deve ser importado para a sessão. Para importar o módulo PSScheduledJob , digite Import-Module PSScheduledJob ou use qualquer cmdlet de trabalho agendado, como Get-ScheduledJob.

Para obter uma lista de todas as instâncias de um trabalho agendado, use o Get-Job cmdlet .

Import-Module PSScheduledJob
Get-Job ProcessJob
Id     Name         PSJobTypeName   State         HasMoreData     Location
--     ----         -------------   -----         -----------     --------
43     ProcessJob   PSScheduledJob  Completed     False           localhost
44     ProcessJob   PSScheduledJob  Completed     False           localhost
45     ProcessJob   PSScheduledJob  Completed     False           localhost
46     ProcessJob   PSScheduledJob  Completed     False           localhost
47     ProcessJob   PSScheduledJob  Completed     False           localhost
48     ProcessJob   PSScheduledJob  Completed     False           localhost
49     ProcessJob   PSScheduledJob  Completed     False           localhost
50     ProcessJob   PSScheduledJob  Completed     False           localhost

O Get-Job cmdlet envia objetos ProcessJob pelo pipeline. O Format-Table cmdlet exibe as propriedades Name, ID e PSBeginTime de uma instância de trabalho agendada em uma tabela.

Get-Job ProcessJob | Format-Table -Property Name, ID, PSBeginTime -Auto
Name       Id PSBeginTime
----       -- ---------
ProcessJob 43 11/2/2011 3:00:02 AM
ProcessJob 44 11/3/2011 3:00:02 AM
ProcessJob 45 11/4/2011 3:00:02 AM
ProcessJob 46 11/5/2011 3:00:02 AM
ProcessJob 47 11/6/2011 3:00:02 AM
ProcessJob 48 11/7/2011 12:00:01 AM
ProcessJob 49 11/7/2011 3:00:02 AM
ProcessJob 50 11/8/2011 3:00:02 AM

Para obter os resultados de uma instância de um trabalho agendado, use o Receive-Job cmdlet . O comando a seguir obtém os resultados da instância mais recente do ProcessJob (ID = 50).

Receive-Job -ID 50

Método básico para localizar resultados de trabalho no disco

Para gerenciar trabalhos agendados, use os cmdlets de trabalho, como Get-Job e Receive-Job.

Se Get-Job não obtém a instância de trabalho ou Receive-Job não obtém os resultados do trabalho, você pode pesquisar os arquivos de histórico de execução para o trabalho no disco. O histórico de execução contém um registro de todas as instâncias de trabalho disparadas.

Verifique se há um diretório nomeado de carimbo de data/hora no diretório para um trabalho agendado no seguinte caminho:

$home\AppData\Local\Microsoft\Windows\PowerShell\ScheduledJob <ScheduledJobName>\Output

Por exemplo:

C:\Users<UserName>\AppData\Local\Microsoft\Windows\PowerShell\ScheduledJob <ScheduledJobName>\Output

Por exemplo, o Get-ChildItem cmdlet obtém o histórico de execução em disco do trabalho agendado do ProcessJob .

$Path = '$home\AppData\Local\Microsoft\Windows\PowerShell'
$Path += '\ScheduledJobs\ProcessJob\Output'
Get-ChildItem $Path
Directory: C:\Users\User01\AppData\Local\Microsoft\Windows\PowerShell
               \ScheduledJobs\ProcessJob\Output

Mode                LastWriteTime     Length Name
----                -------------     ------ ----
d----         11/2/2011   3:00 AM            20111102-030002-260
d----         11/3/2011   3:00 AM            20111103-030002-277
d----         11/4/2011   3:00 AM            20111104-030002-209
d----         11/5/2011   3:00 AM            20111105-030002-251
d----         11/6/2011   3:00 AM            20111106-030002-174
d----         11/7/2011  12:00 AM            20111107-000001-914
d----         11/7/2011   3:00 AM            20111107-030002-376

Cada diretório nomeado por carimbo de data/hora representa uma instância de trabalho. Os resultados de cada instância de trabalho são salvos em um arquivo Results.xml no diretório nomeado de carimbo de data/hora.

Por exemplo, o comando a seguir obtém os arquivos Results.xml para cada instância salva do trabalho agendado processJob . Se o arquivo Results.xml estiver ausente, o PowerShell não poderá retornar ou exibir os resultados do trabalho.

$Path = '$home\AppData\Local\Microsoft\Windows\PowerShell'
$Path += '\ScheduledJobs\ProcessJob\Output\*\Results.xml'
Get-ChildItem $Path
Directory: C:\Users\User01\Appdata\Local\Microsoft\Windows\PowerShell
               \ScheduledJobs\ProcessJob\Output

O cmdlet de trabalho pode não conseguir obter instâncias de trabalho agendadas ou seus resultados porque o módulo PSScheduledJob não é importado para a sessão.

Observação

Antes de usar um cmdlet de trabalho em instâncias de trabalho agendadas, verifique se o módulo PSScheduledJob está incluído na sessão. Sem o módulo PSScheduledJob , os cmdlets de trabalho não podem obter instâncias de trabalho agendadas ou seus resultados.

Para importar o módulo PSScheduledJob :

Import-Module PSScheduledJob

Receive-Job cmdlet pode já ter retornado os resultados

Se Receive-Job não retornar resultados da instância de trabalho, pode ser porque um Receive-Job comando foi executado para essa instância de trabalho na sessão atual sem o parâmetro Keep .

Quando você usa Receive-Job sem o parâmetro Keep , Receive-Job retorna os resultados do trabalho e define a propriedade HasMoreData da instância de trabalho como False. O valor False significa que Receive-Job retornou os resultados do trabalho e a instância não tem mais resultados a serem retornados. Essa configuração é apropriada para trabalhos em segundo plano padrão, mas não para instâncias de trabalhos agendados, que são salvos em disco.

Para obter os resultados da instância de trabalho novamente, inicie uma nova sessão do PowerShell digitando PowerShell. Importe o módulo PSScheduledJob e tente o Receive-Job comando novamente.

Receive-Job -ID 50
#No results
PowerShell.exe
Windows PowerShell
Copyright (C) 2012 Microsoft Corporation. All rights reserved.
Import-Module PSScheduledJob
Receive-Job -ID 50
Handles  NPM(K)    PM(K)      WS(K) VM(M)   CPU(s)     Id  ProcessName
-------  ------    -----      ----- -----   ------     --  -----------
1213         33    12348      21676    88    25.71   1608  CcmExec
29            4     1168       2920    43     0.02    748  conhost
46            6     2208       4612    45     0.03   1640  conhost

Usando o parâmetro Keep para obter resultados mais de uma vez em uma sessão

Para obter o resultado de uma instância de trabalho mais de uma vez em uma sessão, use o parâmetro Keep do Receive-Job cmdlet .

Import-Module PSScheduledJob
Receive-Job -ID 50 -Keep
Handles  NPM(K)    PM(K)      WS(K) VM(M)   CPU(s)     Id  ProcessName
-------  ------    -----      ----- -----   ------     --  -----------
1213         33    12348      21676    88    25.71   1608  CcmExec
29            4     1168       2920    43     0.02    748  conhost
46            6     2208       4612    45     0.03   1640  conhost
Receive-Job -ID 50 -Keep
Handles  NPM(K)    PM(K)      WS(K) VM(M)   CPU(s)     Id  ProcessName
-------  ------    -----      ----- -----   ------     --  -----------
1213         33    12348      21676    88    25.71   1608  CcmExec
29            4     1168       2920    43     0.02    748  conhost
46            6     2208       4612    45     0.03   1640  conhost

O trabalho agendado pode estar corrompido

Se um trabalho agendado ficar corrompido, o PowerShell excluirá o trabalho agendado corrompido e seus resultados. Não é possível recuperar os resultados de um trabalho agendado corrompido.

Para determinar se um trabalho agendado ainda existe, use o Get-ScheduledJob cmdlet .

Get-ScheduledJob

O número de resultados pode ter excedido ExecutionHistoryLength

A propriedade ExecutionHistoryLength de um trabalho agendado determina quantas instâncias de trabalho e seus resultados são salvas em disco. O valor padrão é 32. Quando o número de instâncias de um trabalho agendado excede esse valor, o PowerShell exclui a instância de trabalho mais antiga para abrir espaço para cada nova instância de trabalho.

Para obter o valor da propriedade ExecutionHistoryLength de um trabalho agendado, use o seguinte formato de comando:

(Get-ScheduledJob <JobName>).ExecutionHistoryLength

Por exemplo, o comando a seguir obtém o valor da propriedade ExecutionHistoryLength do trabalho agendado ProcessJob .

(Get-ScheduledJob ProcessJob).ExecutionHistoryLength

Para definir ou alterar o valor da propriedade ExecutionHistoryLength , use o parâmetro MaxResultCount dos Register-ScheduledJob cmdlets e Set-ScheduledJob .

O comando a seguir aumenta o valor da propriedade ExecutionHistoryLength para 50.

Get-ScheduledJob ProcessJob | Set-ScheduledJob -MaxResultCount 50

Os resultados da instância de trabalho podem ter sido excluídos

O parâmetro ClearExecutionHistory do Set-ScheduledJob cmdlet exclui o histórico de execução de um trabalho. Você pode usar esse recurso para liberar espaço em disco ou excluir resultados que não são necessários, ou já usados, analisados ou salvos em um local diferente.

Para excluir o histórico de execução de um trabalho agendado, use o parâmetro ClearExecutionHistory do trabalho agendado.

O comando a seguir exclui o histórico de execução do trabalho agendado do ProcessJob .

Get-ScheduledJob ProcessJob | Set-ScheduledJob -ClearExecutionHistory

Além disso, o Remove-Job cmdlet exclui os resultados do trabalho. Quando você usa Remove-Job para excluir um trabalho agendado, ele exclui todas as instâncias do trabalho no disco, incluindo o histórico de execução e todos os resultados do trabalho.

Os trabalhos iniciados usando o cmdlet Start-Job não são salvos no disco

Quando você usa Start-Job para iniciar um trabalho agendado, em vez de usar um gatilho de trabalho, Start-Job inicia um trabalho em segundo plano padrão. O trabalho em segundo plano e seus resultados não são armazenados no histórico de execução do trabalho no disco.

Você pode usar o Get-Job cmdlet para obter o trabalho e o Receive-Job cmdlet para obter os resultados do trabalho, mas os resultados só estarão disponíveis até você recebê-los, a menos que você use o parâmetro Keep do Receive-Job cmdlet.

Além disso, os trabalhos em segundo plano e seus resultados são específicos da sessão; eles existem apenas na sessão em que são criados. Se você excluir o trabalho com Remove-Job, feche a sessão ou feche o PowerShell, a instância de trabalho e seus resultados serão excluídos.

O trabalho agendado não é executado

Os trabalhos agendados não serão executados automaticamente se o trabalho for disparado ou o trabalho agendado estiver desabilitado.

Use o Get-ScheduledJob cmdlet para obter o trabalho agendado. Verifique se o valor da propriedade Enabled do trabalho agendado é True.

Get-ScheduledJob ProcessJob
Id         Name            Triggers        Command         Enabled
--         ----            --------        -------         -------
4          ProcessJob      {1, 2}          Get-Process     True
(Get-ScheduledJob ProcessJob).Enabled
True

Use o Get-JobTrigger cmdlet para obter os gatilhos de trabalho do trabalho agendado. Verifique se o valor da propriedade Enabled do gatilho de trabalho é True.

Get-ScheduledJob ProcessJob | Get-JobTrigger
Id      Frequency    Time                   DaysOfWeek            Enabled
--      ---------    ----                   ----------            -------
1       Weekly       11/7/2011 5:00:00 AM   {Monday, Thursday}    True
2       Daily        11/7/2011 3:00:00 PM                         True
Get-ScheduledJob ProcessJob|Get-JobTrigger|Format-Table ID, Enabled -Auto
Id Enabled
-- -------
1    True
2    True

Os trabalhos agendados não serão executados automaticamente se os gatilhos de trabalho forem inválidos

Por exemplo, um gatilho de trabalho pode especificar uma data no passado ou uma data que não ocorre, como a 5ª segunda-feira do mês.

Os trabalhos agendados não serão executados automaticamente se as condições do gatilho de trabalho ou as opções de trabalho não forem atendidas.

Por exemplo, um trabalho agendado que é executado somente quando um usuário específico faz logon no computador não será executado se esse usuário não fizer logon ou se conectar apenas remotamente.

Examine as opções do trabalho agendado e verifique se elas estão satisfeitas. Por exemplo, um trabalho agendado que exige que o computador esteja ocioso ou exija uma conexão de rede ou tenha uma IdleDuration longa ou um breve IdleTimeout pode nunca ser executado.

Use o Get-ScheduledJobOption cmdlet para examinar as opções de trabalho e seus valores.

Get-ScheduledJob -Name ProcessJob
StartIfOnBatteries     : False
StopIfGoingOnBatteries : True
WakeToRun              : True
StartIfNotIdle         : True
StopIfGoingOffIdle     : False
RestartOnIdleResume    : False
IdleDuration           : 00:10:00
IdleTimeout            : 01:00:00
ShowInTaskScheduler    : True
RunElevated            : False
RunWithoutNetwork      : True
DoNotAllowDemandStart  : False
MultipleInstancePolicy : IgnoreNew
JobDefinition          : Microsoft.PowerShell.ScheduledJob.ScheduledJobDefinition

Para obter descrições das opções de trabalho agendadas, consulte New-ScheduledJobOption.

A instância de trabalho agendada pode ter falhado

Se um comando de trabalho agendado falhar, o PowerShell o relatará imediatamente gerando uma mensagem de erro. No entanto, se o trabalho falhar quando o Agendador de Tarefas tentar executá-lo, o erro não estará disponível para o PowerShell.

Use os seguintes métodos para detectar e corrigir falhas de trabalho:

Verifique se há erros no log de eventos do Agendador de Tarefas. Para marcar o log, use Visualizador de Eventos ou um comando do PowerShell, como o seguinte:

Get-WinEvent -LogName Microsoft-Windows-TaskScheduler/Operational |
 Where {$_.Message -like "fail"}

Verifique o registro do trabalho no Agendador de Tarefas. Os trabalhos agendados do PowerShell são armazenados na seguinte pasta Agendada de Tarefas:

Task Scheduler Library\Microsoft\Windows\PowerShell\ScheduledJobs

O trabalho agendado pode não ser executado devido à permissão insuficiente

Trabalhos agendados são executados com as permissões do usuário que criou o trabalho ou as permissões do usuário especificado pelo parâmetro Credential no Register-ScheduledJob comando ou Set-ScheduledJob .

Se esse usuário não tiver permissão para executar os comandos ou scripts, o trabalho falhará.

Não é possível obter trabalho agendado ou o trabalho agendado está corrompido

Em raras ocasiões, os trabalhos agendados podem ficar corrompidos ou conter contradições internas que não podem ser resolvidas. Normalmente, isso acontece quando os arquivos XML do trabalho agendado são editados manualmente, resultando em XML inválido.

Quando um trabalho agendado está corrompido, o PowerShell tenta excluir o trabalho agendado, seu histórico de execução e seus resultados do disco.

Se ele não puder remover o trabalho agendado, você receberá uma mensagem de erro de trabalho corrompida sempre que executar o Get-ScheduledJob cmdlet.

Para remover um trabalho agendado corrompido, use um dos seguintes métodos:

Exclua o <ScheduledJobName> diretório do trabalho agendado. Não exclua o diretório ScheduledJob .

O local do diretório:

$env:UserProfile\AppData\Local\Microsoft\Windows\PowerShell \ScheduledJobs<ScheduledJobName>

Por exemplo:

C:\Users<UserName>\AppData\Local\Microsoft\Windows\PowerShell\ ScheduledJobs<ScheduledJobName>.

Use o Agendador de Tarefas para excluir o trabalho agendado. As tarefas agendadas do PowerShell aparecem no seguinte caminho do Agendador de Tarefas:

Task Scheduler Library\Microsoft\Windows\PowerShell \ScheduledJobs<ScheduledJobName>

Os cmdlets de trabalho não conseguem localizar trabalhos agendados de forma consistente

Quando o módulo PSScheduledJob não está na sessão atual, os cmdlets de trabalho não podem obter trabalhos agendados, iniciá-los ou obter seus resultados.

Para importar o módulo PSScheduledJob , digite Import-Module PSScheduledJob ou execute ou obtenha qualquer cmdlet no módulo, como o Get-ScheduledJob cmdlet . A partir do PowerShell 3.0, os módulos são importados automaticamente quando você obtém ou usa qualquer cmdlet no módulo.

Quando o módulo PSScheduledJob não está na sessão atual, a sequência de comandos a seguir é possível.

Get-Job ProcessJob
Get-Job : The command cannot find the job because the job name
ProcessJob was not found.
Verify the value of the Name parameter, and then try the command again.
+ CategoryInfo          : ObjectNotFound: (ProcessJob:String) [Get-Job],
PSArgumentException
+ FullyQualifiedErrorId : JobWithSpecifiedNameNotFound,Microsoft.PowerShell.
Commands.GetJobCommand
Get-Job
Get-ScheduledJob ProcessJob
Id         Name            Triggers        Command      Enabled
--         ----            --------        -------      -------
4          ProcessJob      {1}             Get-Process  True
Get-Job ProcessJob
Id     Name         PSJobTypeName   State       HasMoreData     Location
--     ----         -------------   -----       -----------     --------
43     ProcessJob   PSScheduledJob  Completed   True            localhost
44     ProcessJob   PSScheduledJob  Completed   True            localhost
45     ProcessJob   PSScheduledJob  Completed   True            localhost
46     ProcessJob   PSScheduledJob  Completed   True            localhost
47     ProcessJob   PSScheduledJob  Completed   True            localhost
48     ProcessJob   PSScheduledJob  Completed   True            localhost
49     ProcessJob   PSScheduledJob  Completed   True            localhost
50     ProcessJob   PSScheduledJob  Completed   True            localhost

Esse comportamento ocorre porque o Get-ScheduledJob comando importa automaticamente o módulo PSScheduledJob e executa o comando .

Confira também

about_Scheduled_Jobs_Basics

about_Scheduled_Jobs_Advanced

about_Scheduled_Jobs

Agendador de Tarefas