Linux_deamon_process 守护进程的学习

 守护进程的学习

在linux或者unix中在系统的引导的时候会开启很多服务,这些服务就叫做守护进程。为了增加灵活性,root可以选择系统开启的模式,这些模式叫做运行级别,每一种运行级别以一定的方式配置系统。 守护进程是脱离于终端并且在后台运行的进程。守护进程脱离于终端是为了避免进程在执行过程中的信息在任何终端上显示并且进程也不会被任何终端所产生的终端信息所打断。

  
  
  
  
  1. # include <stdio.h> 
  2. # include <stdlib.h> 
  3. # include <string.h> 
  4.  
  5. # include <unistd.h> 
  6. # include <sys/stat.h> 
  7. # include <sys/param.h> 
  8. # include <sys/types.h> 
  9. # include <signal.h> 
  10.  
  11.  
  12. int    init_deamon(void
  13.     pid_t   pid; 
  14.     int     i; 
  15.  
  16.     if((pid = fork()) == -1) 
  17.     { 
  18.         exit(-1); 
  19.     } 
  20.     if(pid > 0) 
  21.     { 
  22.         //父进程退出,使shell成为前台进程 
  23.         exit(0); 
  24.     } 
  25.     //第一进程 
  26.     //第一进程成为新会话和新进程的领头进程同时也失去控制端 
  27.     setsid(); 
  28.     if((pid = fork()) == -1) 
  29.     { 
  30.         exit(-1); 
  31.     } 
  32.     if(pid > 0 ) 
  33.     { 
  34.         exit(0); 
  35.     } 
  36.     //孙进程 
  37.     for(i = 0; i<NOFILE;++i) 
  38.     { 
  39.         close(i); 
  40.     } 
  41.     chdir("/tmp"); 
  42.  
  43.     umask(0); //改变文件创建掩码 
  44.  
  45.     return
  46.  
  47. //每隔30s向/tmp/test.log报告系统中正在运行和运行过的进程列表 
  48. int    main() 
  49.     FILE    *fp; 
  50.     FILE    *p; 
  51.     char    buf[256]; 
  52.  
  53.     init_deamon(); 
  54.  
  55.     while(1) 
  56.     { 
  57.         sleep(30); 
  58.  
  59.         if((fp = fopen("/tmp/test.log","a")) > 0) 
  60.         { 
  61.             p = popen("ps -ef","r"); 
  62.             while(fgets(buf,sizeof(buf),p) != 0) 
  63.             { 
  64.                 fprintf(fp,"%s\n",buf); 
  65.             } 
  66.             pclese(p); 
  67.         } 
  68.         fclose(fp); 
  69.     } 
  70.  
  71.     exit(0); 

 

 

 

本文出自 “享受科技带来的快乐” 博客,转载请与作者联系!

你可能感兴趣的:(linux,守护进程)