/* *功能:建立一个守护进程,监视系统全部运行的进程 *时间:2013.4.14 */ #include <unistd.h> #include <signal.h> #include <sys/types.h> #include <sys/stat.h> #include <stdio.h> #include <stdlib.h> #include <sys/resource.h> //建立一个守护进程 void init() { int pid; int i; struct rlimit rl; //获取进程资源西限制 if (getrlimit(RLIMIT_NOFILE, &rl) < 0) //获取进程最多文件数 printf(":can't get file limit"); if(pid = fork()) exit(0); //父进程,退出 else if(pid < 0) //开辟进程失败,退出并关闭全部进程 exit(1); /* 子进程继续执行 */ setsid(); //建立新的会话组,子进程成为组长,并与控制终端分离 /* 防止子进程(组长)获取控制终端 */ if(pid = fork()) exit(0); //父进程,退出 else if(pid < 0) exit(1); //开辟进程失败,退出并关闭全部进程 /* 第二子进程继续执行 , 第二子进程再也不是会会话组组长*/ /* 关闭打开的文件描述符*/ if (rl.rlim_max == RLIM_INFINITY) //RLIM_INFINITY是一个无穷量的限制 rl.rlim_max = 1024; for (i = 0; i < rl.rlim_max; i++) close(i); chdir("/tmp"); // 切换工做目录 umask(0); // 重设文件建立掩码 return; } int main() { FILE *fp; FILE *fstream; signal(SIGCHLD, SIG_IGN); // 忽略子进程结束信号,防止出现僵尸进程 init(); //初始化守护进程,就是建立一个守护进程 while(1) { /*PID 进程ID ,user:进程开辟用户,comm:进程名,lstart:进程开始时间,etime:进程持续时间*/ fstream=popen("ps -eo pid,user,comm,lstart,etime>test.txt","r"); //若是执行命令失败,则写入错误报告 if(fstream==NULL) { //在打开或者建立error.log成功的状况下,写入错误(使用errno时失败) if((fp = fopen("error.log", "a+")) != NULL) { fprintf(fp, "%s\n", "执行命令失败"); fclose(fp); } else exit(1); //写入错误失败,则终止程序推出并关闭全部进程 } else pclose(fstream); //关闭popen打开的I/O流 sleep(120); //设置成5分钟获取一次系统进程状况 } return 0; }