有没有办法将任务调度器历史记录信息放入批处理或PowerShell脚本中的数组或变量中。
例如,获取任务名称、任务开始时间(事件ID: 100 )、任务完成时间(事件ID: 102)等信息。这样我就可以用这些信息更新SQL数据库了。( sql表可能如下所示,我知道如何在获得信息后插入到数据库中)
TaskName TaskStart TaskCompleted
task1 27/09/2017 09:00:00 27/09/2017 10:00:00
task2 27/09/2017 12:00:00 27/09/2017 16:00:00
task1 04/10/2017 09:00:00 04/09/2017 09:55:00
基本上,我不知道如何检索这些信息,如果可能的话。谢谢
发布于 2017-09-27 17:38:08
任务计划程序将记录到以下事件通道:
Microsoft-Windows-TaskScheduler/Operational
您可以使用Get-WinEvent
来收集事件。首先,为id 100
启动事件定义一个过滤器哈希表。
# Event filter for the initial query for all "Start" events in the last 24 hours
$EventFilter = @{
LogName = 'Microsoft-Windows-TaskScheduler/Operational'
Id = 100
StartTime = [datetime]::Now.AddDays(-1)
}
我们需要从start事件中提取一些属性值,以便找到相关的完成事件,所以让我们创建一个属性选择器
# PropertySelector for the Correlation id (the InstanceId) and task name
[string[]]$PropertyQueries = @(
'Event/EventData/Data[@Name="InstanceId"]'
'Event/EventData/Data[@Name="TaskName"]'
)
$PropertySelector = New-Object System.Diagnostics.Eventing.Reader.EventLogPropertySelector @(,$PropertyQueries)
现在检索启动事件,找到对应的完成事件,并将信息作为新的自定义对象输出:
# Loop through the start events
$TaskInvocations = foreach($StartEvent in Get-WinEvent -FilterHashtable $EventFilter){
# Grab the InstanceId and Task Name from the start event
$InstanceId,$TaskName = $StartEvent.GetPropertyValues($PropertySelector)
# Create custom object with the name and start event, query end event by InstanceId
[pscustomobject]@{
TaskName = $TaskName
StartTime = $StartEvent.TimeCreated
EndTime = $(Get-WinEvent -FilterXPath "*[System[(EventID=102)] and EventData[Data[@Name=""InstanceId""] and Data=""{$InstanceId}""]]" -LogName 'Microsoft-Windows-TaskScheduler/Operational' -ErrorAction SilentlyContinue).TimeCreated
}
}
可以使用$TaskInvocations
中的对象填充DataTable
,也可以根据属性值生成插入查询
https://stackoverflow.com/questions/46452001
复制相似问题