linux守护进程编程实例代码:
/*
*功能:创建一个守护进程,监视系统所有运行的进程
*时间:2016.6.20
*/
#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;
}
代码结束。
本文永久更新地址://m.ajphoenix.com/linux/21677.html