您的位置:首页 > 运维架构 > Linux

Linux之守护进程

2016-07-20 21:46 239 查看
守护进程是在操作系统运行起来以后常驻内存的进程,这些进程默默的在后台进行这自己的工作,当然我们是发现不了的,在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来结束这个进程

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: