dameon
     dameon进程也叫守护进程,当我们需要一个没有前台终端,在后台一直运行的进程时,我们怎么办?写一个程序,在运行的时候加&实行后台运行,这是一种拙劣的办法。unix有专门的守护进程。
基本知识:
      守护进程是在后台运行,没有实现用户交互的前台终端,在unix下显示为?;守护进程都是要在超级用户的权限下跑的;守护进程的父进程都是init进程(进程号为1);守护进程是unix默认下都是以d结尾的,表dameon,用户自己写的守护进程最好也以d结尾;除update,其它的守护进程都是所在进程组的组长;
       用ps查看前台进程,用ps -e查看所有的进程
程序范例:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<fcntl.h>
#include<sys/types.h>
#include<unistd.h>
#include<sys/wait.h>
#include<syslog.h>
        
#define MAXFILE 65535
int main()
{
 pid_t pc;
 int i,j,fd,len;
 char *buf="This is a Dameon\n";
 len =strlen(buf);
 printf("father process id=%d\n",getpid());
 pc=fork(); //创建一个子进程
 if(pc<0)    //子进程创建错误
 {
  printf("error fork\n");//跑到前台去
  exit(1);
 }
 else if(pc>0)//如果fork函数返回的id>0,说明在父进程中
 {
         printf("fork return value>0,so in father process id=%d\n",getpid());
         exit(0); //退出父进程
 }
 printf("son process id=%d\n",getpid());
 openlog("demo_update",LOG_PID, LOG_DAEMON);//在子进程中
            //demo_update显示在:的前面,这一点类似于perror
 setsid();
            //创建一个会话,并成为这个会话组组长,也是唯一成员,剥离终端,使此子进程成为一个孤儿
            //进程,由init进程接管
 sleep(1);
            //创建一个新会话,要稍微等会才行,没那么快
 syslog(LOG_ERR, "dddddddddd=====%d\n", getppid());
           //已经剥离终端,不能用printf,这个getppin()返回init进程id,为1
 chdir("/");
          //改变当前目录为根目录,因为,这个程序一直在跑,将引起不能删除或修改某个文件系统
 umask(0);
          //因为由继承来的文件方式可能屏蔽掉了某些位,所以去掉屏蔽,比如可读,可写位
 for(i=0;i<MAXFILE;i++)
      close(i);
          //由父进程处可能继承了不需要的打开文件,所以关掉文件描述符,当然某些文件需要的话,
          //可以不关闭
 if((fd=open("home/nsl/myprogram/dameon.log",O_CREAT|O_WRONLY|O_APPEND,0600))<0)     //打开文件
 {
  perror("/nsl/myprogram/dameon.log---open");
  exit(1);
 }
 for(j=0;j<100;j++)
 {
  write(fd, buf, len+1);//向里面写入"This is dameon"
  sleep(10);
 }
 closelog();  //关闭log
 close(fd);   //关掉这个文件描述符
 return 0;
}
注:
   syslog()写的log在/var/log/里面的messages里面