您的位置:首页 > 其它

守护进程和inetd超级服务器

2013-06-26 20:52 399 查看
守护进程(daemon)一般在系统自举时启动,直到系统关闭时才终止。没有控制终端,在后台运行。

编写守护进程的规则:

1、首先umask将文件屏蔽字设置为0

原因:由父进程继承来的文件屏蔽字,可能屏蔽了读写权限,所以回复初始权限

2、fork子进程,然后父进程exit退出,(一般fork两次)

原因:子进程继承父进程的进程组ID,但是有新的进程ID,这就保证子进程不是一个进程组的组长,为了是setsid成立一个新的会话。

3、调用setsid创建一个新的会话使进程具有:

a、成为新会话的首进程;

b、成为一个新进程组的组长进程;

c、没有控制终端

4、当当前目录改为根目录,chdir("\")

5、关闭不再需要的文件描述符

4000
6、打开/dev/null,使其具有描述符0 1 2

7、打开日志,输出。

下面为UNP上的示例程序,很清晰的表明了编程规则。daemon_init(const char *pname, int facility)
{
int i;
pid_t pid;

if ( (pid = Fork()) < 0)
return (-1);
else if (pid)
_exit(0); /* parent terminates */

/* child 1 continues... */

if (setsid() < 0) /* become session leader */
return (-1);

Signal(SIGHUP, SIG_IGN); //忽略SIGHUP信号,因为当会话首进程终止时(就是第一次产生的子进程),会话中所有进程都会收到hup信号
if ( (pid = Fork()) < 0)
return (-1);
else if (pid)
_exit(0); /* child 1 terminates */

/* child 2 continues... */

daemon_proc = 1; /* for err_XXX() functions */

chdir("/"); /* change working directory */

/* close off file descriptors */
for (i = 0; i < MAXFD; i++)
close(i);

/* redirect stdin, stdout, and stderr to /dev/null */
open("/dev/null", O_RDONLY);
open("/dev/null", O_RDWR);
open("/dev/null", O_RDWR);

openlog(pname, LOG_PID, facility);

return (0); /* success */
}

一、syslogd守护进程

通过syslogd守护进程,用来处理后台日志信息。我们常用的使用syslog函数来与守护进程通信,输出日志信息。

#include <syslog.h>
void syslog(int priority, const chat *massage,...) //如以上程序

二、inetd守护进程

(1)通过使用inetd守护进程,可以处理守护进程的大部分编程规则,使得简化守护进程的编写。

(2)单个进程(inetd)能为多个服务等待外来的客户请求,取代了每个服务一个进程的做法,减少了系统中的进程数。(使用select机制来实现)

(3)主要通过读取/etc/inetd.conf的配置文件来处理各种服务,我们使用时只要编写配置文件,通过inetd来实现守护进程。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  daemon 守护进程