如何获得像“top”命令一样的per-cpu统计信息(system,idle,nice,...)?

时间:2010-01-23 10:07:27

标签: c linux cpu-usage

在linux上,我想知道要调用什么“C”API来获取per-cpu统计信息。

我知道并且可以从我的应用程序中读取/proc/loadavg,但这是系统范围的加载avarages,而不是per-cpu信息。我想分开各个CPU或核心。

作为执行此操作的应用程序的示例,当我运行top并按“1”时,我可以看到这样的4或8个处理器/核心:

Cpu0  :  4.5%us,  0.0%sy,  0.0%ni, 95.5%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Cpu1  : 42.2%us,  6.2%sy,  0.5%ni, 51.2%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st
Cpu2  :  3.0%us,  1.5%sy,  0.0%ni, 94.5%id,  0.0%wa,  0.0%hi,  1.0%si,  0.0%st
Cpu3  :  7.0%us,  4.7%sy,  0.0%ni, 88.3%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%st

我试过strace top但这导致了老鼠的窝。

3 个答案:

答案 0 :(得分:6)

您想要的文件是/proc/stat。 (您可能希望在Linux内核源代码中引用fs/proc/stat.c。)

答案 1 :(得分:2)

这不是一个真正的答案,但我会看一下top的源代码。

答案 2 :(得分:0)

我认为内核文件timer.c在这种情况下可能具有一定的重要性来计算负载平均值。从文件timer.c函数calc_load()

unsigned long avenrun[3];

static inline void calc_load(unsigned long ticks) 
{

    unsigned long active_tasks; /* fixed-point */
    static int count = LOAD_FREQ;

    count -= ticks;
    if (count < 0) {
        count += LOAD_FREQ;
        active_tasks = count_active_tasks();
        CALC_LOAD(avenrun[0], EXP_1, active_tasks);
        CALC_LOAD(avenrun[1], EXP_5, active_tasks);
        CALC_LOAD(avenrun[2], EXP_15, active_tasks);
    }
}