守护进程设计

1.什么是守护进程

守护进程,也就是通常说的Daemon精灵进程,是linux中的一种服务进程。它的特点是:

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

*独立于控制终端

×周期性运行

技术分享

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

pid=fork();
if(pid>0)
    exit(0); //父进程退出
else if(pid==0)
{
    //守护进程
}
独立于控制终端
守护进程不能占用控制终端,因此需要在后台运行。实现方
法是调用setsid()函数。
pid=fork();
if(pid>0)
    exit(0); //父进程退出
else if(pid==0) //守护进程
{
    setsid();
    。。。。。。
}

摆脱父进程影响

技术分享

修改工作目录

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

修改文件权限掩码
文件权限掩码是指屏蔽掉文件权限中的对应位。比如掩码是500,它就屏蔽了文件创建者的可读与可执行权限。由于子进程要继承父进程的文件权限掩码,这势必影响子进程中新创建的文件的访问权限,为避免该影响,就需要重新对子进程中的权限掩码清零。通常的使用方法为函数:
umask(0)

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

综合实例

/* daemon.c */

#include <stdio.h>
#include <unistd.h>
#include <fcntl.h>

int main()
{
	pid_t pid;
	char *buff = "I am daemon";
	int fd;
	int flag=1;
	int i;
	
	//创建子进程
	pid = fork();
	if(pid<0)
	{
		printf("fork error!\n");
		exit(1);
	}
	if(pid>0)
	{
		exit(0);
	}
	//脱离控制终端
	setsid();
	
	//改变工作目录
	chdir("/");
	
	//清除掩码
	umask(0);
	
	//关闭打开的文件
	for(i=0; i<65535; i++)
	{
		close(i);
	}
	
	//守护进程的实际工作
	while(1)
	{
		if((flag==1)&&(fd=open("/tmp/daemon.log",O_CREAT|O_WRONLY|O_APPEND,0600))<0)
		{
			printf("open file error\n");
			flag = 0;
			exit(1);
		}
		write(fd,buff,strlen(buff));
		close(fd);
		sleep(1);
	}
	
	return 0;
}


郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。