(1)创建子进程,父进程退出
首先做的是调用fork,然后使父进程exit.这样做实现了下面几点:
第一,如果该守护进程是一条简单shell命令起动的,那么使父进程终止使得shell认为这条命令已经执行完成。
第二,子进程继承了父进程的进程组ID,但具有一个新的进程ID,这就保证了子进程不是一个进程组的首进程。这对于下面就要做的setsid调用是必须的前提条件。
(2)调用setsid以创建一个新的会话,并担任该会话组的组长。调用setsid作用有三个:
(a)成为新对话期的首进程,
(b)成为一个新进程组的首进程,
(c)脱离控制终端。
(会话组是一个或多个进程组的集合)
setsid()函数格式:
#include
#include
Pid_t setsid(void)
函数成功时返回该进程组ID,出错时返回-1
(3)改变当前目录为根目录
chdir("/");
从父进程继承过来的当前工作目录可能在一个mnt的文件系统中。因为守护进程通常在系统再引导之前是一直存在的,所以如果守护进程的当前工作目录在一个mnt文件系统中,那么该文件系统就不能被拆卸。
(4)重设文件权限掩码
umask(0);
由继承得来的文件方式创建屏蔽字可能会拒绝设置某些许可权。例如,若守护进程要创建一个组可读、写的文件,而继承的文件方式创建屏蔽字,屏蔽了这两种许可权,则所要求的组可读、写就不能起作用。
(5)关闭不再需要的文件描述符。
用fork函数创建的子程序会从父进程那继承一些已经打开的文件,由此为使守护进程就不再持有从其父进程继承来的某些文件描述符。但是,究竟关闭哪些描述符则与具体精灵进程有关,可以程序中的方法关闭所有文件描述符。
for(i=0;i
close(i);
守护进程的出错处理
由于守护进程完全脱离了控制终端,因此,不能像其他程序一样通过输出错误信息到控制台的方式来通知程序员。
通常的办法是使用syslog服务,将出信息输入到“/var/log/message”系统日志文件中去。
syslog是linux中的系统日志管理服务通过守护进程syslog来维护。
syslog函数说明
Openlog函数用于打开系统日志服务的一个连接;
Syslog函数用于向日志文件中写入消息,
在这里可以规定消息的优先级、消息的输出格式等;
Closelog函数用于关闭系统日志服务的连接.
(1)openlog函数
#include
void openlog(char * ident,int option, int facility);
Ident: 要向每个消息加入的字符串,通常为程序的名称;
option参数:
LOG_CONS: 若日志消息不能通过发送至syslogd,则将该消息写至控制台;
LOG_NDELAY:立即打开UNIX域数据报套接口至syslsgd守护进程。通常,在记录第一条消息之前,该套接口不打开。
LOG_PERROR:除将日志消息发送给syslog外,还将它写至标准出错(stderr)
LOG_PID:每条消息都包含进程ID,此选择项可供对每个请求都fork一个子进程的守护进程使用.
facility参数:
LOG_AUTH 授权程序:lgin.su,getty
LOG_CRONcron 和 at
LOG_DAEMON 系统守护进程:ftpd ,routed,
LOG_KERN内核产生的消息,
LOG_LOCAL0~7 保留由本地使用
LOG_MAIL 邮件系统
LOG_NEWSU senet网络新闻系统
LOG_SYSLOG syslogd守护进程本身
LOG_USER 来自其他用户进程的消息
LOG_UUCP UUCP系统
(2)syslog函数
#include
void syslog(int priority,char *format,...);
Priority选项(消息优先级)
LOG_EMERG 紧急(系统不可使用)(最高优先级)
LOG_ALERT 必须立即修复的条件
LOG_CRIT 临界条件(例如,硬设备出错)
LOG_ERR 出错条件
LOG_WARNING 警告条件
LOG_INFO 信息性消息
LOG_DEBUG 调试排错消息(最低优先级)
(3)closelog函数
#incude
void closelog(void);
阅读(791) | 评论(0) | 转发(0) |