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里面