如何通过 WPT 来分析 Windows 启动过程

1 篇文章 0 订阅
1 篇文章 0 订阅

引入

所谓 WPT 也就是 Windows Performance Toolkit,包含 Windows Performance Recorder (WPR) 和 Windows Performance Analyzer (WPA) 两个。

其中 WPR 主要用于场景的录制;WPA 主要用于录制后的 ETL 的分析。

当然支撑 WPT 运行的就是 ETW(Event trace for windows) 的机制,通过录制过程中的日志,再通过 WPA 将日志文件打开。而 ETW 在 Windows 的各处都存在。因此,我们就可以利用 WPT 来分析 Windows 启动的过程。

ps:当然,在 Windows 加载前的步骤,肯定是记录不了的。

开始抓日志

安装 WPT

WPT 被包含在了 Windows Assessment and Deployment Kit (Windows ADK) 中,可以通过下载 Windows ADK 安装后,就可以安装好 WPT 了。

💡 WPA 已经可以在 Microsoft Store 中下载了。目前 WPR 还不行。

抓日志

  • 打开 WPA,选择“More options”

  • 在【performance scenario】中选择【Boot】,也就是选择性能场景为开机。其他默认就好。最后那个【Number of iterations】就是选择开机几次,这里选择了 2 次,默认是 3 次。
  • 然后就可以点击开始了。剩下的就全交给 WPA 即可。它会主动触发关机,然后开机
  • 额外的,可以通过【Ctrl + Alt + Win + x】添加标记,后续分析的时候可以用
  • 待处理完成后,打开日志文件夹,就可以看到两个 *.Boot.etl 文件。就像下图:

开始分析

选择任意一个 etl 文件,通过 WPA 来打开即可。

 💡 这里需要注意,如果打开出现 0x80070032 的错误,这是由于 .net 7 的应用截止到写下此文时,WPA 还不支持打开。通过通过在 Microsoft Store 安装 WPA Preview 来解决。

就像上图这样,左侧就是记录的主要数据了,分为 System Activity、Computation、Storage、Memory、Power、Other 这个几个类型。

我们先来看看 Other 类:

WPA 本身就帮我们分了启动的阶段了。双击图标,就可以在右侧看到更相信的信息了。

接下来,我们主要关注的就是进程相关信息了。

进程在 System Activity 中

于是我们就可以看到下图这样的布局了:

通过在 Boot Phases 中选择特定的阶段,右边的时间轴就会被选择,对应的进程也会被选择。

这就是 seesion init 过程的进程情况,我们可以看到先是 smss.exe(420) 起来了,并且整个生命周期都没有退出,也就是我们在任务管理器中看到的那个。

然后就是 smss.exe(512) 了,可以看到它存活的时间只有 0.3s,那它干了啥呢?

然后就可以看到 csrss.exe、wininit.exe 等都启动了。

依此类推,我们可以看到整个启动过程中的进程启动顺序了。如果你还想看线程、堆栈等信息,也可以选择对应的信息。

关于 Windows 启动更详细的信息,可以看:Windows 启动过程分析

  • 23
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Windows操作系统提供了一些内存泄漏检测工具,可以帮助开发人员识别和解决内存泄漏问题。 1. Windows Performance Toolkit:Windows性能工具包(WPT)包括各种工具,其中包含了用于分析和检测内存泄漏的工具。WPT中的堆分析器(Heap Profiler)可以帮助检测应用程序中的内存泄漏,并生成详细的报告。它可以跟踪程序中的内存分配和释放,并标记出没有释放的内存块。 2. Visual Studio Diagnostic Tools:微软的Visual Studio集成开发环境(IDE)提供了一些强大的诊断工具。Visual Studio的诊断工具可以通过内存监视器(Memory Profiler)检测和分析内存泄漏问题。开发人员可以使用这些工具来监视和跟踪应用程序中的内存使用情况,并识别出内存泄漏的原因。 3. 第三方工具:除了Windows官方提供的工具之外,还有一些第三方工具可用于检测和解决内存泄漏问题。例如,MemProfiler是一款用于.NET应用程序的高级内存分析工具,可以帮助开发人员找出内存泄漏的源头。另外,Valgrind是一款开源的内存调试和性能分析工具,可以在Linux和Mac OS X上进行内存泄漏检测。 总之,针对Windows操作系统,开发人员可以使用官方提供的Windows Performance Toolkit和Visual Studio Diagnostic Tools,或者选择一些第三方工具来检测和解决内存泄漏问题。这些工具可以帮助开发人员识别内存泄漏的原因,提高应用程序的性能和稳定性。 ### 回答2: Windows操作系统中的内存泄漏是指程序在运行过程中分配的内存未能释放,导致系统内存资源的浪费和性能下降。为了解决和检测这种问题,Windows提供了一些工具。 1. Windows性能监视器(Performance Monitor):可以用来监测和分析系统的性能指标,包括内存使用情况。通过查看内存使用率的波动,可以推测是否存在内存泄漏的情况。 2. 内存诊断工具(Memory Diagnostics Tool):Windows自带的内存诊断工具可以检测和诊断系统中的硬件问题,包括内存故障和内存泄漏。可以通过启动该工具来进行运行时内存检测。 3. 调试工具(Debugger):Windows提供了强大的调试工具集,如WinDBG和Visual Studio。这些工具可以通过附加到运行中的程序来实时追踪和分析系统中的内存泄漏。 4. 第三方工具:除了Windows自带的工具,还有一些第三方工具可用于检测和分析Windows内存泄漏问题。例如,MemProfiler和LeakDiag等工具提供了更高级的功能,可以帮助开发人员更容易地定位和解决内存泄漏问题。 总结起来,Windows提供了多种工具来帮助检测和解决内存泄漏问题,开发人员可以根据具体情况选择合适的工具来进行内存泄漏的定位和修复。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值