Sobre trabalhos agendados avançados
Descrição breve
Explica os tópicos avançados de trabalho agendado, incluindo a estrutura de arquivos que é subjacente aos trabalhos agendados.
Descrição longa
Diretórios e arquivos de trabalho agendados
Trabalhos agendados do PowerShell são trabalhos do PowerShell e tarefas do Agendador de Tarefas. Cada trabalho agendado é registrado no Agendador de Tarefas e salvo em disco no formato XML de Serialização do Microsoft .NET Framework.
Quando você cria um trabalho agendado, o PowerShell cria um diretório para o trabalho agendado no $home\AppData\Local\Microsoft\Windows\PowerShell\ScheduledJobs
diretório no computador local. O nome do diretório é o mesmo que o nome do trabalho.
Veja a seguir um diretório ScheduledJobs de exemplo.
Get-ChildItem $home\AppData\Local\Microsoft\Windows\PowerShell\ScheduledJobs
Directory: C:\Users\User01\AppData\Local
\Microsoft\Windows\PowerShell\ScheduledJobs
Mode LastWriteTime Length Name
---- ------------- ------ ----
d---- 9/29/2011 10:03 AM ArchiveProjects
d---- 9/30/2011 1:18 PM Inventory
d---- 10/20/2011 9:15 AM Backup-Scripts
d---- 11/7/2011 10:40 AM ProcessJob
d---- 11/2/2011 10:25 AM SecureJob
d---- 9/27/2011 1:29 PM Test-HelpFiles
d---- 9/26/2011 4:22 PM DeployPackage
Cada trabalho agendado tem seu próprio diretório. O diretório contém o arquivo XML do trabalho agendado e um subdiretório Output .
$Path = "$home\AppData\Local\Microsoft\Windows\PowerShell"
$Path += "\ScheduledJobs\ProcessJob"
Get-ChildItem $Path
Directory: C:\Users\User01\AppData\Local\Microsoft\Windows\PowerShell
\ScheduledJobs\ProcessJob
Mode LastWriteTime Length Name
---- ------------- ------ ----
d---- 11/1/2011 3:00 PM Output
-a--- 11/1/2011 3:43 PM 7281 ScheduledJobDefinition.xml
O diretório Saída de um trabalho agendado contém seu histórico de execução. Sempre que um gatilho de trabalho inicia um trabalho agendado, o PowerShell cria um diretório chamado carimbo de data/hora no diretório de saída. O diretório timestamp contém os resultados do trabalho em um arquivo Results.xml e o trabalho status em um arquivo Status.xml.
O comando a seguir mostra os diretórios do histórico de execução para o trabalho agendado do ProcessJob .
$Path = "$home\AppData\Local\Microsoft"
$Path += "\Windows\PowerShell\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
$Path = "$home\AppData\Local\Microsoft\Windows\PowerShell\"
$Path += "ScheduledJobs\ProcessJob\Output\20111102-030002-260"
Get-ChildItem $Path
Directory: C:\Users\User01\AppData\Local\Microsoft\Windows\PowerShell
\ScheduledJobs\ProcessJob\Output\20111102-030002-260
Mode LastWriteTime Length Name
---- ------------- ------ ----
-a--- 11/2/2011 3:00 AM 581106 Results.xml
-a--- 11/2/2011 3:00 AM 9451 Status.xml
Você pode abrir e examinar os arquivosScheduledJobDefinition.xml, Results.xml e Status.xml ou usar o Select-XML
cmdlet para analisar os arquivos.
Aviso
Não edite os arquivos XML. Se qualquer arquivo XML contiver XML inválido, o PowerShell excluirá o trabalho agendado e seu histórico de execução, incluindo os resultados do trabalho.
Iniciar um trabalho agendado imediatamente
Você pode iniciar um trabalho agendado imediatamente de duas maneiras:
- Execute o
Start-Job
cmdlet para iniciar qualquer trabalho agendado. - Adicione o parâmetro RunNow ao comando
Register-ScheduledJob
para iniciar o trabalho assim que o comando for executado.
Os trabalhos iniciados usando o Start-Job
cmdlet são trabalhos em segundo plano padrão do PowerShell, não instâncias do trabalho agendado. Como todos os trabalhos em segundo plano, esses trabalhos começam imediatamente, eles não estão sujeitos a opções de trabalho ou afetados por gatilhos de trabalho. A saída do trabalho não é salva no diretório Saída do diretório de trabalho agendado.
O comando a seguir usa o parâmetro DefinitionName do Start-Job
cmdlet para iniciar o trabalho agendado do ProcessJob.
Start-Job -DefinitionName ProcessJob
Para gerenciar o trabalho e obter os resultados do trabalho, use os cmdlets de trabalho. Para obter mais informações sobre os cmdlets de trabalho, consulte about_Jobs.
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
.
Renomear um trabalho agendado
Para renomear um trabalho agendado, use o parâmetro Name do Set-ScheduledJob
cmdlet . Quando você renomeia um trabalho agendado, o PowerShell altera o nome do trabalho agendado e o diretório de trabalho agendado. No entanto, ele não altera os nomes das instâncias do trabalho agendado que já foram executados.
Obter horários de início e término
Para obter as datas e horas que as instâncias de trabalho iniciaram e terminaram, use as propriedades PSBeginTime e PSEndTime do objeto ScheduledJob que Get-Job
retorna para trabalhos agendados.
O exemplo a seguir usa o parâmetro Property do Format-Table
cmdlet para exibir as propriedades PSBeginTime e PSEndTime de cada instância de trabalho em uma tabela. Uma propriedade calculada chamada Label exibe o tempo decorrido de cada instância de trabalho.
Get-job -Name UpdateHelpJob |
Format-Table -Property ID, PSBeginTime, PSEndTime,
@{Label="Elapsed Time";Expression={$.PsEndTime - $.PSBeginTime}}
Id PSBeginTime PSEndTime Elapsed Time
-- ----------- --------- ------------
2 11/3/2011 3:00:01 AM 11/3/2011 3:00:39 AM 00:00:38.0053854
3 11/4/2011 3:00:02 AM 11/4/2011 3:01:01 AM 00:00:59.1188475
4 11/5/2011 3:00:02 AM 11/5/2011 3:00:50 AM 00:00:48.3692034
5 11/6/2011 3:00:01 AM 11/6/2011 3:00:54 AM 00:00:52.8013036
6 11/7/2011 3:00:01 AM 11/7/2011 3:00:38 AM 00:00:37.1930350
7 11/8/2011 3:00:01 AM 11/8/2011 3:00:57 AM 00:00:56.2570556
8 11/9/2011 3:00:03 AM 11/9/2011 3:00:55 AM 00:00:51.8142222
9 11/10/2011 3:00:02 AM 11/10/2011 3:00:42 AM 00:00:40.7195954
Gerenciar histórico de execução
Você pode determinar o número de resultados da instância de trabalho que são salvos para cada trabalho agendado e excluir o histórico de execução e os resultados salvos do trabalho de qualquer trabalho agendado.
A propriedade ExecutionHistoryLength de um trabalho agendado determina quantos resultados da instância de trabalho são salvos para o trabalho agendado. Quando o número de resultados salvos excede o valor da propriedade ExecutionHistoryLength , o PowerShell exclui os resultados da instância mais antiga para abrir espaço para os resultados da instância mais recente.
Por padrão, o PowerShell salva o histórico de execução e os resultados de 32 instâncias de cada trabalho agendado. Para alterar esse valor, use os parâmetros MaxResultCount dos Register-ScheduledJob
cmdlets ou Set-ScheduledJob
.
Para excluir o histórico de execução e todos os resultados de um trabalho agendado, use o parâmetro ClearExecutionHistory do Set-ScheduledJob
cmdlet. Excluir esse histórico de execução não impede que o PowerShell salve os resultados de novas instâncias do trabalho agendado.
O exemplo a seguir usa splatting para criar $JobParms
quais são valores de parâmetro que são passados para o Register-ScheduledJob
cmdlet. Para obter mais informações, consulte about_Splatting.md.
O Register-ScheduledJob
usa @JobParms
para criar um trabalho agendado. O comando usa o parâmetro MaxResultCount com um valor de 12 para salvar apenas os 12 resultados mais recentes da instância de trabalho do trabalho agendado.
$JobParms = @{
Name = "ProcessJob"
ScriptBlock = {Get-Process}
MaxResultCount = "12"
}
Register-ScheduledJob @JobParms
O comando a seguir usa o parâmetro MaxResultCount do Set-ScheduledJob
cmdlet para aumentar o número de resultados da instância salva para 15.
Get-ScheduledJob ProcessJob | Set-ScheduledJob -MaxResultCount 15
O comando a seguir exclui o histórico de execução e os resultados salvos atuais do trabalho agendado do ProcessJob .
Get-ScheduledJob ProcessJob | Set-ScheduledJob -ClearExecutionHistory
O comando a seguir obtém os valores das propriedades name e ExecutionHistoryLength de todos os trabalhos agendados no computador e os exibe em uma tabela.
Get-ScheduledJob |
Format-Table -Property Name, ExecutionHistoryLength -AutoSize