学习TraceLogging事件,使用ETW记录,并使用WPA捕获和分析跟踪

优化响应行为的交互

下载WINDOWS评估和部署工具包 (Windows ADK)

保持默认安装

驱动延迟优化的基本步骤包括:

  1. 定义方案并添加 TraceLogging 事件。TraceLogging 是用于日志记录事件的系统,无需清单即可解码,TraceLogging基于windows事件跟踪(ETW),并提供检测代码的简化办法。C#可选的有.NET EventSource类,WinRT有LoggingChannel,社区支持的TraceLoggingDynamic。
  2. 根据交互类设置目标,用户对应用的性能和响应能力有不同的期望。
  3. 若要检查特定交互的确切持续时间,可以使用 Windows 性能分析器 (WPA) 捕获和分析跟踪。
  4. 分析跟踪并查找改进机会。

学习使用TraceLogging

  1. 创建EventSource,创建 EventSource 类的实例。 第一个构造函数参数标识此提供程序的名称。

    private static EventSource log = new EventSource("TraceLoggingProvider");
    

    实例标注为静态,因为一次应用程序中只有一个特定提供程序的一个实例。

  2. 日志TraceLogging事件

    log.Write("Event 1");
    
    log.Write("Event 2", new { someEventData = DateTime.Now });
    
    ExampleStructuredData EventData = new ExampleStructuredData() { TransactionID = 1234, TransactionDate = DateTime.Now };
    log.Write("Event 3", EventData); 
    
    [EventData]  
    public sealed class ExampleStructuredData
    {
       public int TransactionID { get; set; }
       public DateTime TransactionDate { get; set; }
    }
    

    注意下面的
    这个Name是你的提供程序记录事件。

    1. 把下面的文件保存成.WPRP后缀,名字随便起。
    <?xml version="1.0" encoding="utf-8"?>
    <!-- TODO: 
    1. Find and replace "TraceLoggingProvider" with the name of your provider.
    2. See TODO below to update GUID for your event provider
    -->
    <WindowsPerformanceRecorder Version="1.0" Author="Microsoft Corporation" Copyright="Microsoft Corporation" Company="Microsoft Corporation">
     <Profiles>
       <EventCollector Id="EventCollector_TraceLoggingProvider" Name="TraceLoggingProvider">
         <BufferSize Value="64" />
         <Buffers Value="4" />
       </EventCollector>
    
       <!-- TODO:
       1. Update Name attribute in EventProvider xml element with your provider GUID, eg: Name="0205c616-cf97-5c11-9756-56a2cee02ca7". Or
          if you specify an EventSource C# provider or call TraceLoggingRegister(...) without a GUID, use star (*) before your provider
          name, eg: Name="*MyEventSourceProvider" which will enable your provider appropriately.
       2. This sample lists one EventProvider xml element and references it in a Profile with EventProviderId xml element.
          For your component wprp, enable the required number of providers and fix the Profile xml element appropriately
       -->
       <EventProvider Id="EventProvider_TraceLoggingProvider" Name="*TraceLoggingProvider" />
    
       <Profile Id="TraceLoggingProvider.Verbose.File" Name="TraceLoggingProvider" Description="TraceLoggingProvider" LoggingMode="File" DetailLevel="Verbose">
         <Collectors>
           <EventCollectorId Value="EventCollector_TraceLoggingProvider">
             <EventProviders>
               <!-- TODO:
               1. Fix your EventProviderId with Value same as the Id attribute on EventProvider xml element above
               -->
               <EventProviderId Value="EventProvider_TraceLoggingProvider" />
             </EventProviders>
           </EventCollectorId>
         </Collectors>
       </Profile>
    
       <Profile Id="TraceLoggingProvider.Light.File" Name="TraceLoggingProvider" Description="TraceLoggingProvider" Base="TraceLoggingProvider.Verbose.File" LoggingMode="File" DetailLevel="Light" />
       <Profile Id="TraceLoggingProvider.Verbose.Memory" Name="TraceLoggingProvider" Description="TraceLoggingProvider" Base="TraceLoggingProvider.Verbose.File" LoggingMode="Memory" DetailLevel="Verbose" />
       <Profile Id="TraceLoggingProvider.Light.Memory" Name="TraceLoggingProvider" Description="TraceLoggingProvider" Base="TraceLoggingProvider.Verbose.File" LoggingMode="Memory" DetailLevel="Light" />
    
     </Profiles>
    </WindowsPerformanceRecorder>
    
    1. 打开CMD使用管理员进入到你保存XML的路径启动wpr.exe

"C:\Program Files (x86)\Windows Kits\10\Windows Performance Toolkit\WPR.exe" -start MyEventSourceProvider.WPRP
5. 允许包含事件的应用程序。
6. 停止跟踪捕获
"C:\Program Files (x86)\Windows Kits\10\Windows Performance Toolkit\WPR.exe" -stop TraceCaptureFile.etl description

使用windows 性能分析器查看TracLogging数据

在刚才的目录下生成一个.etl文件,WPA是目前唯一可以查看TracLogging文件的查看器

  1. 启动WPA, 加载文件
    "C:\Program Files (x86)\Windows Kits\10\Windows Performance Toolkit\WPA.exe" TraceCaptureFile.etl
  2. 查看提供程序事件。在WPA图形资源管理器中,展开“系统活动(System Activity)”。
  3. 双击“泛型事件(Generic Events)”中的分析窗格中的事件。
  4. 在分析窗格中,找到提供程序的事件,验证TraceLogging是否正常工作。
Microsoft Windows [版本 10.0.22621.1555]
(c) Microsoft Corporation。保留所有权利。

C:\Users\Administrator>cd D:\WinUI3\TraceLogging

C:\Users\Administrator>d:

D:\WinUI3\TraceLogging>"C:\Program Files (x86)\Windows Kits\10\Windows Performance Toolkit\WPR.exe" -start MyEventSourceProvider.WPRP

D:\WinUI3\TraceLogging>"C:\Program Files (x86)\Windows Kits\10\Windows Performance Toolkit\WPR.exe" -stop TraceCaptureFile.etl description

D:\WinUI3\TraceLogging>"C:\Program Files (x86)\Windows Kits\10\Windows Performance Toolkit\WPA.exe" TraceCaptureFile.etl
  1. 在分析窗口中,可以看到我们创建的TraceLoggingProvider的Event1、Event2、Event3。

图床不能用了。没有图了,自己测试一下就好了。

后续的资料。
Windows 性能分析器 | Microsoft Learn

原文链接:https://www.cnblogs.com/duwenlong/archive/2023/04/25/17354389.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:学习TraceLogging事件,使用ETW记录,并使用WPA捕获和分析跟踪 - Python技术站

(0)
上一篇 2023年4月27日
下一篇 2023年4月27日

相关文章

  • c# 获取照片的经纬度和时间的示例代码

    要获取照片的经纬度和时间,我们可以使用C#语言中的ExifLib库来实现。下面我将为大家详细讲解如何使用ExifLib库来获取照片的经纬度和时间。 准备工作 在使用ExifLib库之前,需要先添加对该库的引用。可以通过NuGet包管理器来添加引用。具体步骤如下: 在Visual Studio中打开你的项目。 在“解决方案资源管理器”窗口中右击项目名称,选择“…

    C# 2023年6月1日
    00
  • C# Path.GetFullPath – 获取路径的完整路径

    Path.GetFullPath 方法是 .NET 中用于获取给定路径的完整路径的静态方法。它将解析任何相对路径,并将其转换为绝对路径。 使用该方法时,可以传递一个字符串类型的路径作为参数,它将返回一个字符串类型的绝对路径。 例如,在 Windows 操作系统下,将字符串 “myFolder/myFile.txt” 作为参数传递给 Path.GetFullP…

    C# 2023年4月19日
    00
  • C# 生转换网页为pdf

    下面我将详细讲解C#如何实现将网页转换为PDF的完整攻略,包括步骤和代码示例。 步骤1:下载使用合适的PDF组件 要生成PDF文件,我们需要使用PDF生成组件。C#中常用的PDF组件包括iTextSharp、PDFSharp以及Winnovative等。这里,我们以iTextSharp为例,进行讲解。 步骤2:创建一个PDF文档对象 在使用iTextShar…

    C# 2023年6月6日
    00
  • .net的socket异步通讯示例分享

    下面我将为您详细讲解“.NET的Socket异步通讯示例分享”的攻略。 一、什么是Socket异步通讯 在计算机网络中,Socket(套接字)是指一个可以收发信息的网络通信端点,常用于客户端与服务器之间的通信。异步通讯是指通讯双方在任何时候都可以独立地发送和接收消息,不需要等待对方的响应。 在.NET中,可以使用Socket类实现Socket异步通讯,它提供…

    C# 2023年5月31日
    00
  • C#多种操作excel的方法比较

    C#多种操作excel的方法比较 概述 在C#中,操作Excel的方法有很多种,我们可以使用COM Interop方式、OleDb方式、ADO.Net方式等。本文将对这些方式进行比较,并给出相应的示例代码。 COM Interop方式 使用COM Interop方式可以使用Excel内置的对象模型来进行Excel文件的读写操作。 示例代码: using Mi…

    C# 2023年6月1日
    00
  • 一个C#开发者重温C++的心路历程

    一个C#开发者重温C++的心路历程 C#作为一门高级别的编程语言,在现代软件工程中有着广泛的应用。虽然C#已经满足了很多业务场景的需求,但是在一些需要性能和资源方面的场景下,使用C++编写程序可能仍然是必要的。本文将详细讲解C#开发者如何重温C++,并在C++编程中如何避免一些常见的坑。 1. 学习C++的基础语法 作为一门中级编程语言,C++的语法既包含了…

    C# 2023年5月14日
    00
  • asp.net StringBuilder的用法 实例代码

    asp.net StringBuilder的用法 简介 StringBuilder 类是 C# 中一个非常有用的字符串操作类,它可以在不产生多个字符串对象的情况下通过追加或插入的方式修改字符串。采用这种方式修改字符串,可以避免产生多个字符串对象的开销,从而提升程序的性能。 示例说明一 下面的代码演示了如何使用 StringBuilder 类创建一个字符串,然…

    C# 2023年5月31日
    00
  • C#处理Access中事务的方法

    下面是详细的”C#处理Access中事务的方法”攻略: 一、事务概述 如果在数据库事务中的一个或多个命令失败了,那么整个事务都应该被撤回。为此,可以使用事务将数据的修改为原子性操作。 Access数据库的事务原理和所有关系型数据库一样,都是基于ACID的: 原子性(Atomicity):要么全部成功,要么全部失败,没有中间状态,回滚(Rollback)整个事…

    C# 2023年5月31日
    00
合作推广
合作推广
分享本页
返回顶部