进程控制开发之:Linux守护进程

时间:2013-09-13来源:网络

(3)使用实例。

这里将上一节中的示例程序用syslog服务进行重写,其中有区别的地方用加粗的字体表示,源代码如下所示:

/*syslog_daemon.c利用syslog服务的守护进程实例*/

#includestdio.h>

#includestdlib.h>

#includestring.h>

#includefcntl.h>

#includesys/types.h>

#includeunistd.h>

#includesys/wait.h>

#includesyslog.h>

intmain()

{

pid_tpid,sid;

inti,fd;

char*buf=ThisisaDaemonn;

pid=fork();/*第一步*/

if(pid0)

{

printf(Errorforkn);

exit(1);

}

elseif(pid>0)

{

exit(0);/*父进程推出*/

}

/*打开系统日志服务,openlog*/

openlog(daemon_syslog,LOG_PID,LOG_DAEMON);

if((sid=setsid())0)/*第二步*/

{

syslog(LOG_ERR,%sn,setsid);

exit(1);

}

if((sid=chdir(/))0)/*第三步*/

{

syslog(LOG_ERR,%sn,chdir);

exit(1);

}

umask(0);/*第四步*/

for(i=0;igetdtablesize();i++)/*第五步*/

{

close(i);

}

/*这时创建完守护进程,以下开始正式进入守护进程工作*/

while(1)

{

if((fd=open(/tmp/daemon.log,

O_CREAT|O_WRONLY|O_APPEND,0600))0)

{

syslog(LOG_ERR,open);

exit(1);

}

write(fd,buf,strlen(buf)+1);

close(fd);

sleep(10);

}

closelog();

exit(0);

}

读者可以尝试用普通用户的身份执行此程序,由于这里的open()函数必须具有root权限,因此,syslog就会将错误信息写入到系统日志文件(例如“/var/log/messages”)中,如下所示:

Jan3018:20:08localhostdaemon_syslog[612]:open

1 2 3 4

关键词: 进程控制 Linux 守护进程 子进程

加入微信
获取电子行业最新资讯
搜索微信公众号:EEPW

或用微信扫描左侧二维码

相关文章

查看电脑版