4

所以,一开始这看起来很简单,但是在爬了谷歌和这里之后,答案似乎并没有我最初想的那么简单。

基本上,我正在编辑一个 MINIX 内核,作为我的操作系统课程实践的一部分,并且我必须添加一个小函数,当您在信息服务器中按下一个功能键时,它会吐出正在运行的进程的数量。我已经想出了如何集成功能,以便所有其他东西都能正常工作,但是对于我的生活,我无法弄清楚如何将系统中运行的当前进程数放入我的 C 代码和变量中以打印。

首先,我认为会有一个漂亮的系统调用,比如 SYS_NUMPROCS 或返回值的东西,但没有运气。然后,我尝试将系统(“ps -ax | wc -l”)的输出通过管道传输到文件,但文件不会创建。我尝试使用 popen() 也没有运气 - 即使将简单的“ls”读入缓冲区,它也只会轰炸代码并“挂起”代码的运行,因此没有输出。

所以现在我真的很难过,任何帮助都会非常棒,因为此时我已经用尽了所有明显的选择。

我现在唯一能想到的两件事是计算所有进程的循环,但首先你必须进入系统的进程列表,我听说过关于 /proc/ 作为目录的模糊说法,但我没有不知道如何访问/运行它,或者它如何链接到首先获取进程数。

谢谢一堆(笑双关语),伙计们:)

此外,我没有明确包含代码,因为除了基本的 printf'ing 用于化妆品输出之外,我没有写任何东西,因为我尝试过的所有东西都没有给我带来任何快乐:/

编辑说明: 伙计们,这是一个内核编辑——我正在编写函数来打印系统 C 文件中的信息,然后重新编译内核并重新启动系统进行测试。它是 UNIX (MINIX) 内核,不是 Linux 内核,也不是用户模式程序。

根据你们中的一些人的要求,我的 popen() 代码如下:

public void cos_dmp(){
    char buffer[512];
    FILE * f;

    f = popen("ps -ax | wc -l","r");

    fgets(buffer, sizeof(buffer),f);

  //buffer should now contain result of popen()

     printf(buffer);
}

这有点像我记忆中的拼凑版本,它保持超简单,并向你们展示我正在尝试做的事情。不过,除了本质上调用 system() 调用的输出之外,还必须有更好的方法来做到这一点。

再次编辑:上面的代码完全可以从用户程序中运行,但不能从内核函数中运行。有人知道为什么吗?:/

4

8 回答 8

3

尝试查看 ps 的作用。查看它的源代码;它知道有多少进程

于 2011-08-29T18:46:04.890 回答
3

也许您可以向我们展示您为捕获 的结果而编写system("ps -ax | wc -l")的代码,或者您为使用popen而编写的代码,我们可以帮助您诊断问题所在。

无论如何,我能想到的计算系统上现有(与正在运行的)进程数的最有效方法是opendir("/proc")计算十进制数字字符串的条目数。系统中的每个进程将由/proc的子目录表示,以该进程的十进制进程 ID 号命名。

因此,例如,如果您找到“/proc/3432”,那么您就知道存在一个 pid 为“3432”的进程。只需计算您找到的名称为十进制数字的子目录的数量。


假设:

  • 你问的是Linux,而不是MINIX
  • 您正在编写用户模式程序,而不是修改内核。
于 2011-08-29T18:47:46.337 回答
3
struct kinfo kinfo;
int nr_tasks, nr_procs;
getsysinfo(PM_PROC_NR, SI_KINFO, &kinfo);
nr_procs = kinfo.nr_pro;

这将为您提供正在运行的进程数

于 2011-09-03T18:44:07.893 回答
1

所以我一直遇到同样的问题并找到了解决方案。(MINIX 3.1)在计算进程的方法中使用此代码:(这是ANSI C)

它只是简单地遍历进程表并计算进程数。

我知道这是一个旧线程,但将来可能会对某人有所帮助。

#include "../pm/mproc.h"

/* inside function */

struct mproc *mp;
int i, n=0;

printf("Number of running processes:\n");

getsysinfo(PM_PROC_NR, SI_PROC_TAB, mproc);

for (i = 0; i<NR_PROCS; i++) {
    mp = &mprocs[i];
    if (mp->mp_pid == 0 && i != PM_PROCS_NR) continue;
    n++;   
}

printf("%d", n);

/* function end */
于 2014-08-25T09:20:10.740 回答
1

我在我的大学有同样的任务,所以如果将来有人需要我会发布我的解决方案。我正在为虚拟机使用 Minix 3.3 和 VMware 播放器。
/usr/src/minix/servers/pm的pm服务器中,有一个glo.h文件,其中包含 pm 服务器使用的各种全局变量。幸运的是,在该文件中,有一个名为procs_in_use的变量被定义为 So simple from a system call 将显示当前正在运行的进程数。您可以通过在循环中间的用户空间程序中 添加函数来测试这一点。EXTERN int procs_in_use;
printf("%d\n",procs_in_use);fork()

再提一提:第一个回答说

struct kinfo kinfo;
int nr_tasks, nr_procs;
getsysinfo(PM_PROC_NR, SI_KINFO, &kinfo);
nr_procs = kinfo.nr_procs;

不适合我。SI_KINFO不再存在,所以你应该使用SI_PROC_TABLE. 权限也可能存在问题,因此您将无法从常规系统调用中调用此函数。可以从您的新系统调用中调用替代函数sys_getkinfo(&kinfo),它的作用与上述相同。问题是kinfo.nr_procs不会返回当前进程的数量,而是可以在操作系统中的最大用户进程数,默认情况下为 256,并且可以在定义 NR_PROCS 的文件中手动更改。另一方面,kinfo.nr_tasks将返回操作系统可以容纳的最大内核进程数,默认为 5。

于 2015-09-17T13:44:35.480 回答
0

看看这个: http: //procps.sourceforge.net/

它有许多做这些事情的小型实用程序的来源。这将是一次很好的学习体验:) 我认为 PS 就如 pm100 所指出的那样。

于 2011-08-29T18:56:17.417 回答
0

如果您正在编辑内核,解决此问题的最有效方法是在每次创建进程(即 task_struct 条目)时维护一个计数(并确保在每次进程终止时减少计数)。

您始终可以使用内置宏循环遍历内核中的进程列表(但它很昂贵,因此您应该尽量避免使用它):

struct task_struct *p;
unsigned int count = 0;
for_each_process(task) {
    count++;
}
于 2011-08-29T18:57:46.233 回答
0

看看这个:http: //sourceforge.net/p/readproc/code/ci/master/tree/

#include"read_proc.h"
int main(void)
{
     struct Root * root=read_proc();
     printf("%lu\n",root->len);
     return 0;
}
于 2014-12-07T17:53:02.093 回答