在特定日期之后检索事件时,Get-WinEvent似乎比Get-EventLog慢:
$SourceComputer = "MyServer"
$LogName = "Security"
$StartDate = (get-date).AddMinutes(-30)
$hashquery = @{logname=$LogName; StartTime=$StartDate}
(Measure-Command -Expression {Get-WinEvent -ComputerName $SourceComputer -FilterHashTable $hashquery}).TotalSeconds
(Measure-Command -Expression {Get-EventLog -Computer $SourceComputer -LogName $Logname -After $StartDate}).TotalSeconds
输出:
Get-WinEvent: 128.8475308
Get-EventLog: 4.5299092
这看起来很奇怪,因为Get-WinEvent应该比旧的Get-EventLog功能更好。我做错了吗?
答案 0 :(得分:2)
... Get-WinEvent应该比老款更好 获取,事件日志...
对于大多数参数,这是正确的。 Get-WinEvent
比Get-EventLog
快,因为Get-EventLog
抓取整个 EventLog,然后本地过滤。
但是,Get-WinEvent
确实有一些警告,第一个是-FilterHashtable
,其中few bugs。
第二个问题是-FilterHashtable
非常缓慢,根据Ansgar Wiechers引用的blog post的底部。建议使用-FilterXML
答案 1 :(得分:1)
根据this blog post,Get-EventLog
在用于远程主机时似乎要慢得多。