• [国嵌攻略][094][守护进程设计]


    守护进程

    守护进程,也就是通常说的Daemon(精灵)进程,是Linux中的一种服务进程。例如smbd进程。它的特点是:

    1.不占用控制终端(后台运行)

    2.独立于控制终端

    3.摆脱父进程影响

    4.周期性处理任务

    不占用控制终端

    守护进程需要独立于任何一个控制终端,实现方法调用是通过创建子进程来充当守护进程,而父进程退出,这样进程就可以在后台运行。

    示例:

    pid = fork();

    if(pid > 0){

        exit(0);   //退出父进程

    }else if(pid == 0){

        //守护进程

    }

    独立控制终端

    守护进程不能占用控制终端,因此需要在后台运行。实现方法调用是setsid()函数。

    示例:

    #include <unistd.h>

    pid = fork();

    if(pid > 0){

        exit(0);   //退出父进程

    }else if(pid == 0){

        //守护进程

        setsid();

    }

    摆脱父进程影响

    1.修改工作目录:

    进程活动时,其工作目录所在的文件系统不能卸载。例如:我们从/mnt/usb目录下启动守护进程,那么如果守护进程的工作目录就是/mnt/usb,我们就无法在守护进程运行的情况下卸载/mnt/usb。所以一般需要将守护进程切换到根目录,使用:chdir(“/”)。

    2.修改文件权限掩码

    文件权限掩码是指屏蔽掉文件权限中的对应位。比如掩码是500,那么就屏蔽了文件创建者的可读和可执行权限。由于子进程要继承父进程的文件权限掩码,那么就会影响子进程中新创建的文件访问权限。为里避免影响,就需要重新对子进程中的权限掩码清零。使用:umask(0)。

    3.关闭打开文件

    同文件权限掩码一样,子进程还会从父进程那里继承一些已经打开的文件。这些被打开的文件可能永远也不会被守护进程打开,但它们一样要消耗系统资源,而且会导致文件所在的文件系统无法卸载。因此在子进程中需要将这些文件关闭。使用:for(i = 0; i < MAXFILE; i++) close(i);

    deamon.c

    #include <unistd.h>
    #include <stdio.h>
    #include <sys/types.h>
    #include <sys/stat.h>
    #include <fcntl.h>
    #include <unistd.h>
    #include <string.h>
    #include <stdlib.h>
    
    void main(){
        //创建守护进程
        int pid;
        
        pid = fork();
        if(pid == 0){
            //脱离控制终端
            setsid();
            
            //改变工作目录
            chdir("/");
            
            //清除文件掩码
            umask(0);
            
            //关闭打开文件
            int i;
            
            for(i = 0; i < 65535; i++){
                close(i);
            }
            
            //守护进程处理
            while(1){
                //打开文件
                int fd;
    
                fd = open("/tmp/daemon.log", O_CREAT | O_WRONLY |O_APPEND, 0777);
                
                //写入数据
                char *buffer = "hello world!
    ";
                
                write(fd, buffer, strlen(buffer));
                
                //关闭文件
                close(fd);
                
                //睡眠等待
                sleep(1);
            }
        }
    }
  • 相关阅读:
    游记&退役记
    Nothing to say
    学习知识点的比较好的blog
    计划做题列表
    后缀自动机小专题
    复数
    FFT学习
    P2900 [USACO08MAR]土地征用Land Acquisition
    # 数位DP入坑
    Hdu 4035 Maze(概率DP)
  • 原文地址:https://www.cnblogs.com/d442130165/p/5234172.html
Copyright © 2020-2023  润新知