windows事件跟踪--ETW(Event Trace For Windows)
来源:互联网 发布:虚拟机windows xp 编辑:程序博客网 时间:2024/04/26 22:27
ETW主要包括3个component:Controller, Provider, and Consumer. 这3个的角色从名字一看就清楚了。
我简单介绍一下使用的方法:
Provider首先应该用RegisterTraceGuids注册一个Event Trace,同时提供给RegisterTraceGuids的还有一个ControlCallback,这个callback在Provider被Controller启动(enable)和停止(disable)的时候会被调用,然后Provider就可以相应地开始用TraceEvent来发送EventTrace或者停止发送。
当然,Provider还要通过这个callback的一个参数来了解应该往哪里送trace,这个参数就是一个由Controller打开的event trace session。什么是event trace session?往下看
Controller的主要任务有两个:一是用StartTrace在内存中创建一个event trace session,这样Provider就知道该往哪里送trace,而Controller也会负责将session里记录的trace送到Consumer手里。Controller的第二个任务就是启动(API: EnableTrace)和停止(API: ControlTrace)Provider。为了避免额外的开销,Provider不会一直都在工作,只有当被Enable的时候,才开始工作(注:其实这么说是不正确的,Provider其实是不必收Controller控制的,它可以随时随地发送trace,只要它知道那个event tracesession的句柄,这完全取决于Provider具体是怎么写的。但在实际操作上,Provider都是根据Controller的Enable/Disable信号来启动和停止tracing的。我自己写的一个snippetprogram是这样,其他现有的正规的Provider也是这样。)
第三个是Consumer,Consumer主要做这几件事:
1. 用OpenTrace打开和event trace session之间的通道。
2. 设计event tracecallback,你可以设计一个generic的callback用来handle所有的eventtrace,不管是不是你感兴趣的。你也可以为特定的eventtrace设计callback,专门处理你关心的trace。Generic的callback实在OpenTrace的时候在参数中指定的,而特定的callback可以用SetTraceCallback来注册。
3. 调用ProcessTrace,开始处理Trace。注意,这里有一个很tricky的地方:ProcessTrace是block的!
就是说ProcessTrace不会返回,除非Controller结束这个session或者Consumer自己调用CloseTrace(注:CloseTrace只有在Longhorn可以使ProcessTrace返回,XP不行)。
呵呵,那你问了,ProcessTrace都不返回,我的Consumer还怎么调用CloseTrace啊? 答案很简单:你需要第二个线程,那个线程什么也没干,就调用了ProcessTrace,然后它就待在那里,直到Consumer的主线程调用CloseTrace或者Controller关闭了整个session。 我知道这个方法很奇怪,但,不要问我,这是ETW team给我的答案,他们肯定有他们的考虑。最后想说的是:很多时候你会发现,Controller和Consumer都是在一个program里的。这个很好理解,Provider都在场面上了,你要用它们发送的trace来取得信息,你的程序当然会既做Controller (打开session,启动Provider)又做Consumer。
TraceLog(PSDK工具),控制ETW(Event Tracing for windows)
StartTrace和EnableTrace打开并开启Trace。
如果StartTrace返回183,则用TraceLog -stop来关闭Trace(该错误就是因为上次的Trace打开没关闭造成)
- windows事件跟踪--ETW(Event Trace For Windows)
- Windows software trace preprocessor (WPP)&Event Tracing for Windows(ETW)
- ETW是什么架构|Event Tracing for Windows
- ETW-Event Tracing for Windows入门
- (ETW) Event Tracing for Windows 入门
- MSDN Webcast预告:.NET 4.0中的新特性系列课程(5):追踪CLR——使用Windows事件跟踪(ETW)观察公共语言运行时CLR(Level 300)
- Windows Event Trace 编程(TDH.lib)
- windows 的鼠标事件(Event)
- windows 的鼠标事件(Event)
- windows 的鼠标事件(Event)
- windows 的鼠标事件(Event)
- .NET 性能测试工具 -- 事件跟踪器(ETW)
- MSDN网络广播预告:.NET 4.0中的新特性系列课程(5):追踪CLR——使用Windows事件跟踪(ETW)观察公共语言运行时CLR(Level 300)
- Windows SDK 编程调试 TRACE for SDK
- Win7、win10下利用ETW Trace跟踪用户的文件读写信息
- ORACLE EVENT事件跟踪
- Windows中多线程同步之事件(Event)
- 跨平台的EVENT事件 windows linux
- 疾病,疾病,还是疾病
- 我网站的后台管理。ASP代码。
- 坚持>
- 问题查询
- 新的开始
- windows事件跟踪--ETW(Event Trace For Windows)
- MFC中CString和STL中string的互换
- SHFileOperation
- Xml中SelectSingleNode方法中的xpath用法
- bencoding编码详细解析
- iTestWare
- welcome-file-list
- String.format函数使用方法介绍(1)
- GUI设计禁忌