【问题标题】:What would make PerformanceCounterCategory.Exists hang indefinitely?什么会使 PerformanceCounterCategory.Exists 无限期挂起?
【发布时间】:2011-05-11 16:42:54
【问题描述】:

我有一个使用性能计数器的应用程序,它已经工作了几个月。现在,在我的开发机器和另一台开发机器上,当我调用 PerformanceCounterCategory.Exists 时它已经开始挂起。据我所知,它无限期地挂起。我使用哪个类别作为输入并不重要,其他使用 API 的应用程序表现出相同的行为。

调试(使用 MS 符号服务器)表明挂起的是对 Microsoft.Win32.RegistryKey 的调用。进一步调查表明,正是这条线挂起:

while (Win32Native.ERROR_MORE_DATA == (r = Win32Native.RegQueryValueEx(hkey, name, null, ref type, blob, ref sizeInput))) { 

这基本上是一个尝试为性能计数器数据分配足够内存的循环。它从size = 65000 开始并进行了几次迭代。在第 4 次通话中,当size = 520000Win32Native.RegQueryValueEx 挂起。

此外,相当令人担忧的是,我在 PerformanceCounterLib.GetData 的参考源中找到了这条评论:

    // Win32 RegQueryValueEx for perf data could deadlock (for a Mutex) up to 2mins in some 
    // scenarios before they detect it and exit gracefully. In the mean time, ERROR_BUSY,
    // ERROR_NOT_READY etc can be seen by other concurrent calls (which is the reason for the 
    // wait loop and switch case below). We want to wait most certainly more than a 2min window. 
    // The curent wait time of up to 10mins takes care of the known stress deadlock issues. In most
    // cases we wouldn't wait for more than 2mins anyways but in worst cases how much ever time 
    // we wait may not be sufficient if the Win32 code keeps running into this deadlock again
    // and again. A condition very rare but possible in theory. We would get back to the user
    // in this case with InvalidOperationException after the wait time expires.

以前有人见过这种行为吗?我能做些什么来解决这个问题?

【问题讨论】:

  • 非常好的研究,+1。是的,继续担心,整个性能计数器 API 变得无法维护。一个过于简单的模型,无法再固定在下一个版本的 Windows 之上。 Vista从中取得了重大突破。祝你好运!
  • 所有 Windows 版本都容易受到该问题的影响吗?

标签: c# .net debugging performancecounter


【解决方案1】:

此问题现已修复,由于此处没有答案,我将在此处添加答案,以防在以后的搜索中找到该问题。

我最终通过停止打印后台处理程序服务(作为临时措施)修复了此错误。

看起来性能计数器的读取实际上需要枚举系统上的打印机(由挂起进程的 WinDbg 转储确认,我可以在堆栈跟踪中看到 winspool 正在枚举打印机,并且卡在网络通话)。这就是系统上实际失败的原因(果然,打开“设备和打印机”窗口也挂起)。令我感到困惑的是,打印机/网络问题实际上会使性能计数器下降。人们会认为在这种情况下内置了某种故障保护功能。

我的猜测是,这是由网络上的打印机/驱动程序损坏造成的。我还没有在受影响的系统上重新启用打印,因为我们正在寻找坏的打印机。

【讨论】:

  • 性能计数器的读取是否有可能导致打印后台处理程序挂起?触发对某些资源的第二个请求,该请求会阻止第一个请求需要完成的某些事情,或者类似的事情?我想这不会改变实际原因 - 一个糟糕的驱动程序 - 但我想知道这个问题是否不会出现,除非你以你之前详述的方式引发它。
  • 这个答案帮助我们解决了一个相关的new PerformanceCounter() 问题。移除旧打印机可防止挂起,并且至少显示了我们正在处理的错误消息。
  • 我遇到了来自 Outlook 加载项的类似问题。你用什么工具来调试的?目前我有进程监视器,但我无法找到死锁
  • @driis 谢谢。在我的情况下,问题原来是机器上运行的 Microsoft EMET 5.5
猜你喜欢
  • 2021-09-14
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-06-29
  • 2011-05-07
  • 2021-04-23
相关资源
最近更新 更多