新闻资讯
看你所看,想你所想

daemon()

daemon()

daemon()

Daemon()程式是一直运行的服务端程式,又称为守护进程。通常在系统后台运行,没有控制终端,不与前台互动,Daemon程式一般作为系统服务使用。Daemon是长时间运行的进程,通常在系统启动后就运行,在系统关闭时才结束。一般说Daemon程式在后台运行,是因为它没有控制终端,无法和前台的用户互动。Daemon程式一般都作为服务程式使用,等待客户端程式与它通信。我们也把运行的Daemon程式称作守护进程。

基本介绍

  • 中文名:Daemon程式
  • 外文名:daemon()
  • 又称:守护进程
  • 用途:作为系统服务使用

实现方法

编写Daemon程式有一些基本的规则,以避免不必要的麻烦。
1、首先是程式运行后调用fork,并让父进程退出。子进程获得一个新的进程ID,但继承了父进程的进程组ID。
2、调用setsid创建一个新的session,使自己成为新session和新进程组的leader,并使进程没有控制终端(tty)。
3、改变当前工作目录至根目录,以免影响可载入档案系统。或者也可以改变到某些特定的目录。
4、设定档案创建mask为0,避免创建档案时许可权的影响。
5、关闭不需要的打开档案描述符。因为Daemon程式在后台执行,不需要于终端互动,通常就关闭STDIN、STDOUT和STDERR。其它根据实际情况处理。
另一个问题是Daemon程式不能和终端互动,也就无法使用printf方法输出信息了。我们可以使用syslog机制来实现信息的输出,方便程式的调试。在使用syslog前需要首先启动syslogd程式,关于syslogd程式的使用请参考它的man page,或相关文档,我们就不在这里讨论了。

例子

一个Daemon程式的例子 编译运行环境为Redhat Linux 8.0。
我们新建一个daemontest.c程式,档案内容如下:
#include<unistd.h>#include<sys/types.h>#include<sys/stat.h>#include<stdlib.h>#include<stdio.h>#include<syslog.h>#include<signal.h>int daemon_init(void){    pid_t pid;    if((pid=fork())<0)return(-1);    elseif(pid!=0)exit(0);/*parentexit*/    /*childcontinues*/    setsid();/*becomesessionleader*/    chdir("/");/*changeworkingdirectory*/    umask(0);/*clearfilemodecreationmask*/    close(0);/*closestdin*/    close(1);/*closestdout*/    close(2);/*closestderr*/    return(0);}void sig_term(intsigno){    if(signo==SIGTERM)        /*catchedsignalsentbykill(1)command*/    {        syslog(LOG_INFO,"programterminated.");        closelog();        exit(0);    }}int main(void){    if(daemon_init()==-1)    {        printf("can'tforkself\n");        exit(0);    }    openlog("daemontest",LOG_PID,LOG_USER);    syslog(LOG_INFO,"programstarted.");    signal(SIGTERM,sig_term);/*arrangetocatchthesignal*/    while(1)    {        sleep(1);/*putyourmainprogramhere*/    }    return(0);}
使用如下命令编译该程式: gcc -Wall -o daemontest daemontest.c编译完成后生成名为daemontest的程式,执行./daemontest来测试程式的运行。
使用ps axj命令可以显示系统中已运行的daemon程式的信息,包括进程ID、session ID、控制终端等内容。
部分显示内容:
PPID PID PGID SID TTY TPGID STAT UID TIME COMMAND
1098 1101 1101 1074 pts/1 1101 S 0 0:00 -bash 1 1581 777 777 ? -1 S 500 0:13 gedit 1 1650 1650 1650 ? -1 S 500 0:00 ./daemontest 794 1654 1654 794 pts/0 1654 R 500 0:00
ps axj 从中可以看到daemontest程式运行的进程号为1650。
我们再来看看/var/log/messages档案中的信息: Apr 7 22:00:32 localhost
daemontest[1650]: program started.
我们再使用kill 1650命令来杀死这个进程,/var/log/messages档案中就会有如下的信息:
Apr 7 22:11:10 localhost daemontest[1650]: program terminated.
使用ps axj命令检查,发现系统中daemontest进程已经没有了。

相关推荐

声明:此文信息来源于网络,登载此文只为提供信息参考,并不用于任何商业目的。如有侵权,请及时联系我们:yongganaa@126.com