守护进程设计
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了守护进程设计相关的知识,希望对你有一定的参考价值。
守护进程设计
课程索引
什么是守护进程
守护进程, 也就是通常说的Daemon( 精灵) 进程,
是Linux中的一种服务进程。 它的特点是:
•不占用控制终端(后台 运行)
•独立于控制终端
•独立于控制终端
•周期性运行
例如: smb
设计要素
2. 1 后台运行
守护进程需要独立于任何一个控制终端。实现方法调用是通
过创建子进程来充当守护进程,而父进程退出,这样子进程
就可以在后台运行。(范例展示)
pid=fork();
if(pid>0)
if(pid>0)
exit(0); //父进程退出
else (pid==0)
{
//守护进程
}
2. 2 独立于控制终端
守护进程不能占用控制终端,因此需要在后台运行。实现方
法是调用 setsid()函数。
pid=fork();
if(pid>0)
exit(0); //父进程退出
exit(0); //父进程退出
else (pid==0) //守护进程
{
setsid();
。。。。。。
}
2. 3 摆脱父进程影响
2. 3. 1 修改工作目录
进程活动时,其工作目录所在的文件系统不能卸载。例如:
我们是从/mnt/usb目录下启动该守护进程的, 那么 如果守
护进程的工作目录就是/mnt/usb,我们就无法在守护进程
还在运行的情况下umount /mnt/usb。所以一般需要将守
护的工作目录切换到根目录。
护的工作目录切换到根目录。
chdir("/");
2. 3. 2 修改文件权限掩码
文件权限掩码是指屏蔽掉文件权限中的对应位。 比如掩码是
500,它就屏蔽了 文件创建者的可读与可执行权限。 由于子
进程要继承父进程的文件权限掩码,这势必影响子进程中 新
创建的文件的访问权限, 为避免该影响,就需要重新对子进
程中的权限掩码清零。 通常的使用方法为函数:
程中的权限掩码清零。 通常的使用方法为函数:
umask(0)
2. 3. 3 关闭打开文件
同 文件权限码一样,子进程还会从父进程那里继承一些已经
打开了 的文件。这些被打开的文件可能永远不会被守护进程
读写, 但它们一样消耗系统资源,而且会导致文件所在的文
件系统无法卸载。因此在子进程中需要将这些文件关闭。
for(i=0;i<MAXFILE;i++)
close(i);
综合实例
daemon.c
1 #include <stdio.h> 2 #include <unistd.h> 3 #include <fcntl.h> 4 int main() 5 { 6 pit_t pid; 7 int i,fd,flag = 1; 8 char *buf = "I am a daemon!\n"; 9 10 //创建子进程 11 pid = fork(); 12 if(pid <0) 13 { 14 printf("fork error!\n"); 15 exit(1); 16 } 17 if(pid >0) 18 { 19 exit(0); 20 } 21 //2.脱离控制终端 22 setsid(); 23 24 //3.1改变工作目录 25 chdir("/"); 26 27 //3.2清除掩码 28 umask(0); 29 30 //3.3关闭打开的文件 31 for(i=0;i<65535;i++) 32 { 33 close(i); 34 } 35 //4.守护进程的实际工作 36 while(1) 37 { 38 if((flag == 1)&&(fd = open("tmp/daemon.log",O_CREAT|O_WRONLY|O_APPEND,0600)) < 0) 39 { 40 printf("open file error!\n"); 41 flag = 0; 42 exit(1); 43 } 44 write(fd,buf,strlen(buf)); 45 close(fd); 46 sleep(1); 47 } 48 return 0; 49 }
以上是关于守护进程设计的主要内容,如果未能解决你的问题,请参考以下文章
.NET跨平台实践:.NetCore.Net5/6 Linux守护进程设计