すべてのプロセスの合計 CPU を計算するためのワンライナーを次に示します。列フィルターを上部の出力に渡すことで調整できます:
top -b -d 5 -n 2 | awk '$1 == "PID" {block_num++; next} block_num == 2 {sum += $9;} END {print sum}'
この情報は /proc/PID/stat
にあります。 ここで、PID は親プロセスのプロセス ID です。親プロセスが子プロセスを待機すると仮定すると、合計 CPU 使用率は utime から計算できます。 、時間 、キュータイム およびcstime :
utime %lu
このプロセスがユーザー モードでスケジュールされた時間。クロック ティックで測定されます (sysconf(_SC_CLK_TCK で割ります)。これには、ゲスト時間、guest_time (仮想 CPU の実行に費やされた時間、以下を参照) が含まれます。ゲストの時間フィールドは、計算からその時間を失いません。
時間 %lu
このプロセスがカーネル モードでスケジュールされている時間。クロック ティックで測定されます (sysconf(_SC_CLK_TCK) で割ります)。
かわいい %ld
このプロセスの待機中の子プロセスがユーザー モードでスケジュールされた時間で、クロック ティックで測定されます (sysconf(_SC_CLK_TCK で除算)) (times(2) も参照)。以下を参照してください)。
cstime %ld
このプロセスの待機中の子プロセスがカーネル モードでスケジュールされている時間。クロック ティックで測定されます (sysconf(_SC_CLK_TCK で除算))。
詳細については、proc(5) マンページを参照してください。
正確なコマンドではない可能性があります。ただし、以下のようにして、さまざまなプロセスの CPU 使用率を取得し、追加することができます。
#ps -C sendmail,firefox -o pcpu= | awk '{s+=$1} END {print s}'
/proc/[pid]/stat プロセスに関するステータス情報。これは ps によって使用され、人間が読める形式に変換されます。
もう 1 つの方法は、cgroups を使用して cpuacct を使用することです。
http://www.kernel.org/doc/Documentation/cgroups/cpuacct.txt
https://access.redhat.com/knowledge/docs/en-US/Red_Hat_Enterprise_Linux/6/html/Resource_Management_Guide/sec-cpuacct.html
そしてもちろん、古き良き C を使用してハードコアな方法でそれを行うこともできます
find_cpu.c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#define MAX_CHILDREN 100
/**
* System command execution output
* @param <char> command - system command to execute
* @returb <char> execution output
*/
char *system_output (const char *command)
{
FILE *pipe;
static char out[1000];
pipe = popen (command, "r");
fgets (out, sizeof(out), pipe);
pclose (pipe);
return out;
}
/**
* Finding all process's children
* @param <Int> - process ID
* @param <Int> - array of childs
*/
void find_children (int pid, int children[])
{
char empty_command[] = "/bin/ps h -o pid --ppid ";
char pid_string[5];
snprintf(pid_string, 5, "%d", pid);
char *command = (char*) malloc(strlen(empty_command) + strlen(pid_string) + 1);
sprintf(command, "%s%s", empty_command, pid_string);
FILE *fp = popen(command, "r");
int child_pid, i = 1;
while (fscanf(fp, "%i", &child_pid) != EOF)
{
children[i] = child_pid;
i++;
}
}
/**
* Parsign `ps` command output
* @param <char> out - ps command output
* @return <int> cpu utilization
*/
float parse_cpu_utilization (const char *out)
{
float cpu;
sscanf (out, "%f", &cpu);
return cpu;
}
int main(void)
{
unsigned pid = 1;
// getting array with process children
int process_children[MAX_CHILDREN] = { 0 };
process_children[0] = pid; // parent PID as first element
find_children(pid, process_children);
// calculating summary processor utilization
unsigned i;
float common_cpu_usage = 0.0;
for (i = 0; i < sizeof(process_children)/sizeof(int); ++i)
{
if (process_children[i] > 0)
{
char *command = (char*)malloc(1000);
sprintf (command, "/bin/ps -p %i -o 'pcpu' --no-headers", process_children[i]);
common_cpu_usage += parse_cpu_utilization(system_output(command));
}
}
printf("%f\n", common_cpu_usage);
return 0;
}
コンパイル:
gcc -Wall -pedantic --std=gnu99 find_cpu.c
お楽しみください!