如何使用 C 从 Linux 上的 /proc 文件的内容中提取信息?

Kha*_*bdo 0 c linux fedora

我一直在为此工作 5 天,每天超过 7 小时。我不是最好的编码员,所以我需要一些帮助。我需要知道如何在 Linux 上使用 C 程序从 /proc 获取信息。信息必须打印出来,并包括以下内容:

  • 进程的完整命令行。
  • 进程状态。
  • 父进程的PID。
  • 优先事项。
  • 不错的价值。
  • 实时调度优先。
  • 上次执行的 CPU 编号。
  • 在用户模式下计划此进程的时间量。
  • 此进程已在内核模式下调度的时间量。
  • 以字节为单位的虚拟内存大小。
  • 程序总大小(以页为单位)。
  • 驻留集大小 (RSS)(以字节为单位)。
  • 驻留集大小 (RSS):进程在实际内存中的页数(以页为单位)。
  • 页中的文本(代码)大小。
  • 数据 + 堆栈大小(以页为单位)。
  • 页表条目大小(以 KB 为单位)。
  • 以 KB 为单位的数据大小。
  • 以 KB 为单位的堆栈大小。
  • 文本段 KB 的大小。

Bri*_*orn 5

听起来你不知道从哪里开始。让我试着解释一下中的信息/proc

如果我们cat /proc/29519/stat,我们会得到以下信息:

29519 (vim) S 5997 29519 5997 34835 29519 24576 1275 0 47 0 5 0 0 0 20 0 2 0 49083340 188043264 3718 18446744073709551615 4194304 6665820 140737488349264 140737488347024 140737280970147 0 0 12288 1837256447 18446744073709551615 0 0 17 3 0 0 21 0 0 8764120 8861948 8925184 140737488349925 140737488349929 140737488349929 140737488351211 0

所有这些数字代表什么?答案在man proc 中,在称为/proc/[pid]/stat. 由此我们看到前四件事是:

pid %d

(1) 进程标识。

通讯 %s

(2) 可执行文件的文件名,在括号中。无论可执行文件是否被换出,这都是可见的。

状态 %c

(3) 字符串“RSDZTW”中的一个字符,其中 R 正在运行,S 在可中断等待中休眠,D 在磁盘不可中断休眠中等待,Z 是僵尸,T 被跟踪或停止(在信号上),W 是分页。

ppid %d

(4) 父母的PID。

有了这些知识,我们可以解析它fscanf(f, "%d %s %c %d", ...)

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>

void main(int argc, char **argv) {
    int pid;
    sscanf(argv[1], "%d", &pid);
    printf("pid = %d\n", pid);

    char filename[1000];
    sprintf(filename, "/proc/%d/stat", pid);
    FILE *f = fopen(filename, "r");

    int unused;
    char comm[1000];
    char state;
    int ppid;
    fscanf(f, "%d %s %c %d", &unused, comm, &state, &ppid);
    printf("comm = %s\n", comm);
    printf("state = %c\n", state);
    printf("parent pid = %d\n", ppid);
    fclose(f);
}
Run Code Online (Sandbox Code Playgroud)

现在,如果我编译该文件并运行./a.out 29519,我会得到

pid = 29519
comm = (vim)
state = S
parent pid = 5997
Run Code Online (Sandbox Code Playgroud)

这是否为您提供了足够的信息以开始使用?