Знание статуса процесса с помощью procf / & lt; pid & gt; / status

Я работаю над солярисом.

Я знаю, что если запущен процесс, существует файл с именем /proc/<PID>/status, где <PID> это идентификатор процесса, и он содержит поле с именем state,

В качестве примера я использовал мой процесс оболочки:

> ps
PID TTY         TIME CMD
18671             0:01 tcsh

чей идентификатор процесса 18671.

Я написал простую программу на C для извлечения этой информации:

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

static void get_status (pid_t pid)
{
char procpath[100];
char buf[100];
int pfd;
char State[100];
char Name[100];
prstatus_t * pms;
FILE *proc;sprintf(procpath, "/proc/%d/status", pid);

proc = fopen(procpath,"r");
if (proc) {
printf("Open Successful\n");
fgets(buf,256,proc); sscanf(buf,"Name:\t%s",Name);
fgets(buf,256,proc); sscanf(buf,"State:\t%c",State);
}
printf("%s",Name);
printf("%s",State);
}

int main(int argc, char **argv)
{
get_status(18671);

}

Это не производит никакого вывода:

> ./a.out
Open Successful
>

В онлайн-материале для procfs говорится, что мы можем просто proc/<pid>/status и проверьте состояние процесса.

Но в моем случае это бинарный файл. Я никогда не видел, чтобы это упоминалось где-то, что это двоичный файл.

Есть ли способ, где я мог бы использовать простую программу на C, чтобы получить состояние текущего процесса?

Решение C ++ также будет приемлемым.

1

Решение

Это структура, которую вы должны прочитать из / proc /pid/статус:

typedef struct pstatus {
int     pr_flags;       /* flags (see below) */
int     pr_nlwp;        /* number of active lwps in the process */
pid_t   pr_pid;         /* process id */
pid_t   pr_ppid;        /* parent process id */
pid_t   pr_pgid;        /* process group id */
pid_t   pr_sid;         /* session id */
id_t    pr_aslwpid;     /* historical; now always zero */
id_t    pr_agentid;     /* lwp id of the /proc agent lwp, if any */
sigset_t pr_sigpend;    /* set of process pending signals */
uintptr_t pr_brkbase;   /* address of the process heap */
size_t  pr_brksize;     /* size of the process heap, in bytes */
uintptr_t pr_stkbase;   /* address of the process stack */
size_t  pr_stksize;     /* size of the process stack, in bytes */
timestruc_t pr_utime;   /* process user cpu time */
timestruc_t pr_stime;   /* process system cpu time */
timestruc_t pr_cutime;  /* sum of children's user times */
timestruc_t pr_cstime;  /* sum of children's system times */
sigset_t pr_sigtrace;   /* set of traced signals */
fltset_t pr_flttrace;   /* set of traced faults */
sysset_t pr_sysentry;   /* set of system calls traced on entry */
sysset_t pr_sysexit;    /* set of system calls traced on exit */
char    pr_dmodel;      /* data model of the process (see below) */
char    pr_pad[3];
taskid_t pr_taskid;     /* task id */
projid_t pr_projid;     /* project id */
int     pr_nzomb;       /* number of zombie lwps in the process */
zoneid_t pr_zoneid;     /* zone id */
int     pr_filler[15];  /* reserved for future use */
lwpstatus_t pr_lwp;     /* status of the representative lwp */
} pstatus_t;

Обратите внимание, что это определено в заголовочном файле procfs.h. Объявить pstatus_t переменная и читать sizeof(pstatus_t) байты в эту переменную.

Совет: также недоступно через lsВы также можете использовать /proc/self/psinfo читать psinfo о самостоятельном процессе.

3

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]