首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

用C语言在Linux上获取程序进程(服务和守护进程)

在 Linux 上,使用 C 语言获取程序进程(服务和守护进程)的方法主要涉及到系统调用和文件操作。以下是一个简单的示例,展示了如何使用 C 语言获取 Linux 上的所有进程信息。

代码语言:c
复制
#include<stdio.h>
#include <stdlib.h>
#include <dirent.h>
#include<string.h>
#include <sys/types.h>
#include <unistd.h>

int main() {
    DIR *proc_dir;
    struct dirent *entry;

    proc_dir = opendir("/proc");
    if (proc_dir == NULL) {
        perror("Failed to open /proc directory");
        return 1;
    }

    while ((entry = readdir(proc_dir)) != NULL) {
        if (entry->d_type == DT_DIR) {
            int pid = atoi(entry->d_name);
            if (pid > 0) {
                printf("PID: %d\n", pid);
            }
        }
    }

    closedir(proc_dir);
    return 0;
}

这个示例程序会遍历 /proc 目录下的所有子目录,每个子目录对应一个进程,其名称为进程 ID。程序会打印出所有进程的 PID。

要获取进程的详细信息,可以读取 /proc/[pid]/status 文件。该文件包含了进程的详细状态信息,例如进程状态、内存使用情况、父进程 ID 等。

代码语言:c
复制
#include<stdio.h>
#include <stdlib.h>
#include<string.h>
#include <sys/types.h>
#include <unistd.h>

int main() {
    int pid = getpid();
    char path[256];
    FILE *file;

    snprintf(path, sizeof(path), "/proc/%d/status", pid);
    file = fopen(path, "r");
    if (file == NULL) {
        perror("Failed to open status file");
        return 1;
    }

    char line[256];
    while (fgets(line, sizeof(line), file) != NULL) {
        printf("%s", line);
    }

    fclose(file);
    return 0;
}

这个示例程序会打印出当前进程的状态信息。

要获取进程的命令行参数,可以读取 /proc/[pid]/cmdline 文件。该文件包含了进程的命令行参数,每个参数之间用 NULL 字符分隔。

代码语言:c
复制
#include<stdio.h>
#include <stdlib.h>
#include<string.h>
#include <sys/types.h>
#include <unistd.h>

int main() {
    int pid = getpid();
    char path[256];
    FILE *file;

    snprintf(path, sizeof(path), "/proc/%d/cmdline", pid);
    file = fopen(path, "r");
    if (file == NULL) {
        perror("Failed to open cmdline file");
        return 1;
    }

    char arg[256];
    while (fgets(arg, sizeof(arg), file) != NULL) {
        printf("%s", arg);
    }

    fclose(file);
    return 0;
}

这个示例程序会打印出当前进程的命令行参数。

要获取进程的环境变量,可以读取 /proc/[pid]/environ 文件。该文件包含了进程的环境变量,每个环境变量之间用 NULL 字符分隔。

代码语言:c
复制
#include<stdio.h>
#include <stdlib.h>
#include<string.h>
#include <sys/types.h>
#include <unistd.h>

int main() {
    int pid = getpid();
    char path[256];
    FILE *file;

    snprintf(path, sizeof(path), "/proc/%d/environ", pid);
    file = fopen(path, "r");
    if (file == NULL) {
        perror("Failed to open environ file");
        return 1;
    }

    char env[256];
    while (fgets(env, sizeof(env), file) != NULL) {
        printf("%s", env);
    }

    fclose(file);
    return 0;
}

这个示例程序会打印出当前进程的环境变量。

以上示例程序展示了如何使用 C 语言获取 Linux 上的进程信息,包括进程 ID、状态信息、命令行参数、环境变量等。这些信息可以用于监控进程状态、调试程序等。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • Linux守护进程的编程实现

    守护进程(Daemon)是执行在后台的一种特殊进程。它独立于控制终端而且周期性地执行某种任务或等待处理某些发生的事件。守护进程是一种非常实用的进程。Linux的大多数server就是用守护进程实现的。比方,Internetserverinetd,Webserverhttpd等。同一时候,守护进程完毕很多系统任务。比方,作业规划进程crond,打印进程lpd等。 守护进程的编程本身并不复杂,复杂的是各种版本号的Unix的实现机制不尽同样,造成不同Unix环境下守护进程的编程规则并不一致。这须要读者注意,照搬某些书上的规则(特别是BSD4.3和低版本号的System V)到Linux会出现错误的。以下将全面介绍Linux下守护进程的编程要点并给出具体实例。 一. 守护进程及其特性 守护进程最重要的特性是后台执行。在这一点上DOS下的常驻内存程序TSR与之类似。其次,守护进程必须与其执行前的环境隔离开来。这些环境包含未关闭的文件描写叙述符,控制终端,会话和进程组,工作文件夹以及文件创建掩模等。这些环境一般是守护进程从执行它的父进程(特别是shell)中继承下来的。最后,守护进程的启动方式有其特殊之处。它能够在Linux系统启动时从启动脚本/etc/rc.d中启动,能够由作业规划进程crond启动,还能够由用户终端(一般是shell)执行。 总之,除开这些特殊性以外,守护进程与普通进程基本上没有什么差别。因此,编写守护进程实际上是把一个普通进程依照上述的守护进程的特性改造成为守护进程。假设读者对进程有比較深入的认识就更easy理解和编程了。 二. 守护进程的编程要点 前面讲过,不同Unix环境下守护进程的编程规则并不一致。所幸的是守护进程的编程原则事实上都一样,差别在于具体的实现细节不同。这个原则就是要满足守护进程的特性。同一时候,Linux是基于Syetem V的SVR4并遵循Posix标准,实现起来与BSD4相比更方便。编程要点例如以下; 1. 在后台执行。 为避免挂起控制终端将Daemon放入后台执行。方法是在进程中调用fork使父进程终止,让Daemon在子进程中后台执行。 if(pid=fork()) exit(0);//是父进程,结束父进程,子进程继续 2. 脱离控制终端,登录会话和进程组 有必要先介绍一下Linux中的进程与控制终端,登录会话和进程组之间的关系:进程属于一个进程组,进程组号(GID)就是进程组长的进程号(PID)。登录会话能够包含多个进程组。这些进程组共享一个控制终端。这个控制终端一般是创建进程的登录终端。 控制终端,登录会话和进程组一般是从父进程继承下来的。我们的目的就是要摆脱它们,使之不受它们的影响。方法是在第1点的基础上,调用setsid()使进程成为会话组长: setsid(); 说明:当进程是会话组长时setsid()调用失败。但第一点已经保证进程不是会话组长。setsid()调用成功后,进程成为新的会话组长和新的进程组长,并与原来的登录会话和进程组脱离。因为会话过程对控制终端的独占性,进程同一时候与控制终端脱离。 3. 禁止进程又一次打开控制终端 如今,进程已经成为无终端的会话组长。但它能够又一次申请打开一个控制终端。能够通过使进程不再成为会话组长来禁止进程又一次打开控制终端:

    02
    领券