2

我过去看过WMI、负 CPU 使用值和 Timestamp_Sys100NS,但我没有做任何事情,只有两个读数之间的增量时间。

当 CPU 使用率非常低时,即系统空闲进程显示为 99%,我得到负 CPU 使用率读数。

我已经改编了 MSDN 文章中的代码和公式,但不知道为什么它可能是错误的。

http://msdn.microsoft.com/en-us/library/aa392397%28VS.85%29.aspx

底部注释掉的行只给了我 0 或 100 的结果,我认为这是因为整数舍入或类似的东西,所以我在除法之前把它分成单独的部分作为双打。

        ulong N1 = 0;
        ulong D1 = 0;
        ulong N2 = 0;
        ulong D2 = 0;

        ManagementScope scope = new ManagementScope("\\\\" + Machine + "\\root\\cimv2");
        scope.Connect();

        WqlObjectQuery wqlQuery = new WqlObjectQuery("SELECT PercentProcessorTime, TimeStamp_Sys100NS FROM Win32_PerfRawData_PerfOS_Processor Where Name = '_Total'");
        ManagementObjectSearcher searcher = new ManagementObjectSearcher(scope, wqlQuery);

        foreach (ManagementObject proc in searcher.Get())
        {
            N1 = ulong.Parse(proc.Properties["PercentProcessorTime"].Value.ToString());
            D1 = ulong.Parse(proc.Properties["TimeStamp_Sys100NS"].Value.ToString());
        }

        System.Threading.Thread.Sleep(500);

        foreach (ManagementObject proc in searcher.Get())
        {
            N2 = ulong.Parse(proc.Properties["PercentProcessorTime"].Value.ToString());
            D2 = ulong.Parse(proc.Properties["TimeStamp_Sys100NS"].Value.ToString());
        }


        double cpu = N2 - N1;
        double time = D2 - D1;
        var x = (1 - (cpu / time)) * 100;
        //var x = (1 - ((N2 - N1) / (D2 - D1))) * 100;
        context.Response.Write(x);
4

1 回答 1

1

我遇到了完全相同的问题,我在示例中使用 Perl,但是您在下面看到的逻辑是相同的,我使用了该 Microsoft 文档中描述的公式。

$average = (1 - ( ($n2-$n1) / ($d2-$d1) ) ) * 100;

我试图解决这个问题好几天,但最后我只是选择了最明显的解决方案:

if ($average <0) { $average = 0; }

最后,如果 CPU 非常低,没有人真正关心。就我而言,我正在寻找负载峰值和远程负载。也许你对我不知道的小变化感兴趣,对我来说 1% 或 0% 是完全一样的。

于 2012-07-24T10:24:57.277 回答