(1) 创建子进程,父进程退出
首先做的是调用fork,然后使父进程exit,这样做实现了下面几点:第一:如果该守护进程是由一条简单的shell命令启动的,那么父进程终止使得shell认为这条命令已经执行完成。第二,子进程继承了父进程的进程组ID,但具有了一个新的进程ID,这就保证了子进程不是一个进程组的首进程。
(2) 调用setsid以创建一个心的会话,并担任会话组的组长,会话组是一个或多个进程组的集合,调用setsid作用有三个:
(a)成为新会话期的首进程
(b)成为一个新进程组的首进程
(c)脱离控制终端
setsid函数格式
#include<sys/types.h>
#include<unist.h>
pid_t setsid(void)
函数成功时返回该进程组的ID,出错时返回-1
(3) 改变当前工作目录为根目录
chdir("/");
从父进程继承过来的当前目录可能在一个mnt的文件系统中,因为守护进程通常在系统再引导之前一直存在的,所以如果守护进程的当前工作目录在一个mnt文件系统中,那么该文件系统就不能被拆卸
(4)重设文件权限掩码
umask(0)
由继承得来的文件方式创建屏蔽字可能会拒绝设置某些许可权,若守护进程要创建一个组可读可写的文件,而继承的文件方式创建屏蔽字,屏蔽了这二种许可权,则所要求的组可读,可写就不能起作用
(5)关闭不再需要的文件描述符
用fork函数创建的子程序会从父进程那里继承一些已经打开的文件,由此为使守护进程不再持有从其父进程继承来的某些文件描述符。但是究竟关闭哪些描述符则与具体的精灵进程有关,可以关闭所有文件描述符