0

当我尝试使用PerfView v1.9.0.0(收集 -> 收集 -> 开始收集,使用默认参数)创建 ETL 文件时,操作失败并显示“发生异常情况,请参阅日志了解详细信息。

以下是我在日志中看到的内容:

Started with command line: "C:\Users\XYZ\Desktop\PerfView.exe" 
PerfView Version: 1.9.0.0  BuildDate: Fri 02/12/2016 11:19:34.83
Started: View
Warning: PdbScope not found at C:\Users\XYZ\Desktop\PerfViewExtensions\PdbScope.exe
Disabling the Image Size Menu Item.
Warning: ILSize not found at C:\Users\XYZ\Desktop\PerfViewExtensions\ILSize.dll
Disabling the IL Size Menu Item.
Completed: View   (Elapsed Time: 0.021 sec)
Collection Dialog open.
Started: Collecting data C:\Users\XYZ\Desktop\PerfViewData.etl
[Kernel Log: C:\Users\XYZ\Desktop\PerfViewData.kernel.etl]
Kernel keywords enabled: Default
Aborting tracing for sessions 'NT Kernel Logger' and 'PerfViewSession'.
Insuring .NET Allocation profiler not installed.
Completed: Collecting data C:\Users\XYZ\Desktop\PerfViewData.etl   (Elapsed Time: 1.300 sec)
Exception Occurred: System.Runtime.InteropServices.COMException (0x800700B7): Cannot create a file when that file already exists. (Exception from HRESULT: 0x800700B7)
   at System.Runtime.InteropServices.Marshal.ThrowExceptionForHRInternal(Int32 errorCode, IntPtr errorInfo)
   at Microsoft.Diagnostics.Tracing.Session.TraceEventSession.EnableKernelProvider(Keywords flags, Keywords stackCapture)
   at PerfView.CommandProcessor.Start(CommandLineArgs parsedArgs)
   at PerfView.CommandProcessor.Collect(CommandLineArgs parsedArgs)
   at PerfView.MainWindow.<>c__DisplayClass13_0.<ExecuteCommand>b__0()
   at PerfView.StatusBar.<>c__DisplayClass19_0.<StartWork>b__0(Object <state>)
An exceptional condition occurred, see log for details.

当然,该文件以前从未存在过,并且在(失败的)操作之后也不存在。每次我尝试收集时都会发生这种情况,无论我提供的文件名或目录如何。

我究竟做错了什么?

4

2 回答 2

2

在 Windows 7 之前,您只能使用一个名为NT Kernel Logger的内核会话。从 Windows 8 开始,您可以创建具有不同名称的新会话。

在 Windows 8、Windows Server 2012 及更高版本上,SystemTraceProvider 最多可用于 8 个记录器会话。记录器会话的前两个插槽是为 NT Kernel Logger 和 Circular Kernel Context Logger 保留的。

所以停止使用NT Kernel Logger(如 Process Explorer、Process Hacker、Resmon)来解决问题的工具。

于 2017-07-14T15:11:23.240 回答
0

谢谢magicandre1981的建议。我确实在使用 Windows 7 并且正在运行Process Hacker。停止 Process Hacker 后,PerfView 能够成功执行收集。干杯。

于 2017-07-13T21:37:24.737 回答