1、守护进程的特点
(1)后台服务进程
(2)独立于控制终端
(3)不受用户登录注销影响
(4)周期性执行某任务
2、进程组
(1)进程组的ID就是组长的进程ID
(2)作为进程组里边的第一进程
3、会话
创建一个会话注意事项
(1)不能是进程组长
(2)有些Linux版本需要root权限执行此操作
(3)创建出新的会话一般会丢弃原有的控制终端
(4)一般步骤;fork创立父子进程,父进程死,子进程创建会话操作(setsid()函数)
获得进程所属的会话ID
(1)pid_t getsid(pid_t pid);
创建一个会话
(1)pid_t setsid(void);
4、创建守护进程模型
(1)fork子进程,父进程退出(案例代码中有3种杀死方法)
(2)子进程创建会话
(3)关闭文件描述符
(4)执行核心工作
代码(请在Linux环境下运行)
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <signal.h>
int main(){
pid_t pid;
pid=fork();//创立子进程
if(pid>0){
// exit(1);
kill(getpid(),9);//9是SIGKILL信号量
// raise(9);
}
else if(pid==0){
setsid();
while(1);
/*
{
printf("hello world\n");//检验后台运行
sleep(1);
}
*/
}
return 0;
}
注:printf("hello world\n");这里我省去了,去掉/* */可以检验后台运行,CTRL+C无法停止运行,若要停止运行请再开一个终端输入ps axj | grep a.out(我这里默认创立为a.out为可执行文件,若有变请随之改变),找到a.out的执行进程ID号,在输入kill -9 ID。(这里假设ID为12954,再输入命令kill -9 12954)。