Chinaunix首页 | 论坛 | 博客
  • 博客访问: 487013
  • 博文数量: 223
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 2145
  • 用 户 组: 普通用户
  • 注册时间: 2014-03-01 10:23
个人简介

该坚持的时候坚持,该妥协的时候妥协,该放弃的时候放弃

文章分类

全部博文(223)

文章存档

2017年(56)

2016年(118)

2015年(3)

2014年(46)

我的朋友

分类: C/C++

2016-10-24 21:18:44

1.什么是守护进程
守护进程,也就是通常说的Daemon(精灵)进程,
是Linux中的一种服务进程。它的特点是:
不占用控制终端(后台运行)
独立于控制终端
周期性运行
例如:smbd

2.1 后台运行
守护进程需要独立于任何一个控制终端。实现方法调用是通
过创建子进程来充当守护进程,而父进程退出,这样子进程
就可以在后台运行。(范例展示)
  1. pid=fork();
  2. if(pid>0)
  3. exit(0); //父进程退出
  4. else (pid==0)
  5. {
  6. //守护进程
  7. }

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

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

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

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


  1. #include <stdio.h>
  2. #include <unistd.h>
  3. #include <fcntl.h>
  4. #include <sys/types.h>
  5. #include <sys/stat.h>


  6. void main()
  7. {
  8.     pid_t pid;
  9.     int i;
  10.     int fd;
  11.     int flag = 1;
  12.     char *buf = "i am a daemon.";
  13.     /*创建子进程*/
  14.     pid = fork();
  15.     if(pid < 0)
  16.     {
  17.         printf("fork error!\n");
  18.     exit(1);
  19.     }
  20.     if(pid > 0)
  21.     {
  22.         exit(0);
  23.     }
  24.     /*脱离控制终端*/
  25.     setsid();

  26.     /*改变工作目录*/
  27.     chdir("/");

  28.     /*清除掩码*/
  29.     umask(0);

  30.     /*关闭打开的文件*/
  31.     for(i=0;i<65535;i++)
  32.         close(i);

  33.     /*守护进程的实际工作*/
  34.     while(1)
  35.     {
  36.         if((flag == 1) && (fd = open("/tmp/daemon.log", O_CREAT|O_WRONLY|O_APPEND, 0600) < 0))
  37.         {
  38.             printf("open file error!\n");
  39.             flag = 0;
  40.             exit(1);
  41.         }
  42.         
  43.     write(fd, buf, strlen(buf));
  44.     close(fd);
  45.     sleep(1);
  46.     }
  47. }

阅读(628) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~