守护进程是在操作系统运行起来以后常驻内存的进程,这些进程默默的在后台进行这自己的工作,当然我们是发现不了的,在linux系统下我们可以使用命令来查看
ps axj 参数a表示列出所有用户的进程,参数x表示列出控制终端的和没有控制终端,参数j列出与作业控制相关的信息
TPGID那一行为-1的表示没有控制终端,也可以说是守护进程
要创建一个守护进程的步骤是这样的:
1.调用umask设置文件掩码为0
2.fork()创建子进程,exit()父进程
3.调用setsid()创建一个新会话
4.将当前工作目录更改为根目录
5.关闭不在需要的文件那描述符
其中最为重要额第三步:setsid()的调用会使得
1).调用进程成为新回话的首进程;
2).调用进程成为一个进程组的组长进程;
3).调用进程没有控制终端;
c语言代码实现如下:
#include<stdio.h>
#include<unistd.h>
#include<stdlib.h>
#include<sys/types.h>
#include<sys/stat.h>
void my_daemon()
{
pid_t pid;
umask(0); //设置文件掩码 0
if(pid=fork()!=0)
{
exit(0);
}
//设置新会话
setsid();
//更改目录
if(chdir("/")<0)
{
printf("child dir error!\n");
return;
}
//关闭文件描述符
close(0);
close(1);
close(2);
}
int main()
{
my_daemon();
//daemon(0,0);
while(1)
;
return 0;
}
当然我们也可以使用系统给的函数daemon();
程序运行后我们可以在后台找到:
可以看到运行代码后我的终端还是可以接受我的命令,所以这个进程是在后台运行的,可以用kill -9来结束这个进程