在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
但这导致了老鼠的窝。
答案 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);
}
}