微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > linux 守护进程编写

linux 守护进程编写

时间:09-12 来源:互联网 点击:

要将工作目录改变到根目录。

对于需要转储核心,写运行日志的进程将工作目录改变到特定目录如 /tmpchdir(/)

6. 重设文件创建掩模

进程从创建它的父进程那里继承了文件创建掩模。它可能修改守护进程所创建的文件的存取位。

为防止这一点,将文件创建掩模清除:umask(0);

7. 处理SIGCHLD信号

处理SIGCHLD信号并不是必须的。

但对于某些进程,特别是服务器进程往往在请求到来时生成子进程处理请求。

如果父进程不等待子进程结束,子进程将成为僵尸进程(zombie)从而占用系统资源。

如果父进程等待子进程结束,将增加父进程的负担,影响服务器进程的并发性能。

在Linux下可以简单地将 SIGCHLD信号的操作设为SIG_IGN。

signal(SIGCHLD,SIG_IGN);

这样,内核在子进程结束时不会产生僵尸进程。

这一点与BSD4不同,BSD4下必须显式等待子进程结束才能释放僵尸进程。

三. 守护进程实例

守护进程实例包括两部分:主程序test.c和初始化程序init.c。

主程序每隔一分钟向/tmp目录中的日志test.log报告运行状态。

初始化程序中的init_daemon函数负责生成守护进程。读者可以利用init_daemon函数生成自己的守护进程。

1. init.c清单

#include unistd.h >

#include signal.h >

#include sys/param.h >

#include sys/types.h >

#include sys/stat.h >

void init_daemon(void)

{

int pid;

int i;

if(pid=fork())

exit(0); //是父进程,结束父进程

else if(pid 0)

exit(1); //fork失败,退出

//是第一子进程,后台继续执行

setsid(); //第一子进程成为新的会话组长和进程组长

//并与控制终端分离

if(pid=fork())

exit(0); //是第一子进程,结束第一子进程

else if(pid 0)

exit(1); //fork失败,退出

//是第二子进程,继续

//第二子进程不再是会话组长

for(i=0;i NOFILE;++i) //关闭打开的文件描述符

close(i);

chdir(/tmp); //改变工作目录到/tmp

umask(0); //重设文件创建掩模

return;

}

2. test.c清单

#include stdio.h >

#include time.h >

void init_daemon(void);//守护进程初始化函数

main()

{

FILE *fp;

time_t t;

init_daemon();//初始化为Daemon

while(1)//每隔一分钟向test.log报告运行状态

{

sleep(60);//睡眠一分钟

if((fp=fopen(test.log,a)) >=0){

t=time(0);

fprintf(fp,Im here at %sn,asctime(localtime(t)) );

fclose(fp);

}

}

}

以上程序在RedHat Linux6.0下编译通过。步骤如下:

编译:gcc -g -o test init.c test.c

执行:./test

查看进程:ps -ef

说明:在系统调用库中有一个库函数可以直接使一个进程变成守护进程,

#include

int daemon(int nochdir, int noclose);

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top