Linux下的守护进程与创建方法

来源:互联网 发布:统计软件 编辑:程序博客网 时间:2024/05/21 10:59

1、我们先来了解一下什么是守护进程?
守护进程也称精灵进程(Daemon),是运行在后台的一种特殊进程。它独立于控制终端并且周期性地执行某种任务或等待处理某些发生的事件。守护进程是生存期长的一种进程。它们常常在系统引导装入时启动,仅在系统关闭时才终止。因为它们没有控制终端,所以说它们是在后台运行的。

2、守护进程的特点:
(1)Linux系统启动时会启动很多系统服务进程,守护进程没有控制终端,不能直接和用户交互
(2)其他进程都是在用户登录或运行程序时创建,在运行结束或用户注销时终止,但守护进程不受用户登录注销的影响,只受开机或者关机的影响。

3、守护进程存在的原因:
daemon函数存在的原因是因为控制终端由于某些原因(如断开终端链接)会发送一些信号的原因。而接收处理这些信号的缺省动作会让进程退出。这些信号会由于终端上敲一些特殊按键而产生。

4、守护进程和后台进程的区别:
(1)守护进程是后台进程,后台进程不一定是守护进程
(2)守护进程运行是与终端无关的,是不能往终端上打消息的
(3)守护进程的会话组和当前目录,文件描述符都是独立的。后台运行只是终端进行了一次fork,让程序在后台执行

5、创建守护进程方法:

创建守护进程最关键的一步是调用setsid函数创建一个新的会话(Session),并成为Session Leader。

#include<unistd.h>pid_t setsid(void);

该函数调用成功时返回新创建的Session的id(其实也就是当前进程的id),出错返回-1。注意,调用这个函数之前,当前进程不允许是进程组的Leader,否则该函数返回-1。要保证当前进程不是进程组的Leader也很容易,只要先fork再调用setsid就行了。fork创建的子进程和父进程在同一个进程组中,进程组的Leader必然是该组的第一个进程,所以子进程不可能是该组的第一个进程,在子进程中调用setsid就不会有问题了。

成功调用该函数的结果是:
(1)创建一个新的Session,当前进程成为Session Leader,当前进程的id就是Session的id。
(2)创建一个新的进程组,当前进程成为进程组的Leader,当前进程的id就是进程组的id。
(3)如果当前进程原本有一个控制终端,则它失去这个控制终端,成为一个没有控制终端的进程。所谓失去控制终端是指,原来的控制终端仍然是打开的,仍然可以读写,但只是一个普通的打开文件而不是控制终端了。

6、创建守护进程的步骤:
(1)调用umask将文件模式创建屏蔽字设置为0
(2)父进程fork出子进程,然后子进程调用setsid,父进程直接退出(保证了子进程不是一个进程组的组长),
(3)调用setsid创建一个新的会话(调用成功会使调用进程成为新会话的首进程,并且成为一个进程组的组长进程,调用进程没有控制终端)
(4)将当前工作目录更改为根目录
(5)关闭不在需要的文件描述符
(6)忽略SIGCHLD信号
无代码无真相,

#include<stdio.h>#include<signal.h>#include<unistd.h>#include<stdlib.h>#include<fcntl.h>#include<sys/stat.h>void mydaemon(){    int i,fd0;    pid_t pid;    struct sigaction sa;    umask(0);    if(pid=fork()>0)  //创建子进程,让父进程退出        return;    setsid();         //创建会话    sa.sa_flags=0;    if(sigaction(SIGCHLD,&sa,NULL<0))        return;    if(pid=fork()>0)        //第二次fork        return;    if(chdir("/")<0)        return ;    close(0);    fd0=open("/dev/null",O_RDWR);    dup2(fd0,1);    dup2(fd0,2);}int main(){   mydaemon();   while(1)       sleep(1);   return 0;}

说明:第二次fork()是为了防止后期操作失误而打开守护进程的终端。
这里写图片描述
既然守护进程在后台运行,那么如何删除一个创建出来的守护进程呢?
可以给进程发9号信号:kill -9 pid,这样就可以了。

0 0
原创粉丝点击