1.关于进程的几个理解:
前台进程是依赖于终端而存在的,一旦终端关闭了,前台的进程也就关闭了,而其实真正的终端并非是我们所看到的终端,可以通过ctrl+alt+f5切换(宏基)。关闭的终端并不影响后台进程的执行。而且,值得注意的是守护进程只有在关机的时候才会停止运行。
2.
进程组:一个或多个进程的集合
前台进程组:一个或多个前台进程组的集合
后台进程组:一个或多个后台进程的集合
进程组id:进程组长进程id,一般是指第一个进程
会话:一个或多个进程组的集合(一次用户登陆的过程)
3
在linux或者unix操作系统中在系统的引导的时候会开启很多服务,这些服务就叫做守护进程。为了增加灵活性,root可以选择系统开启的模式,这些模式叫做运行级别,每一种运行级别以一定的方式配置系统。 守护进程是脱离于终端并且在后台运行的进程。守护进程脱离于终端是为了避免进程在执行过程中的信息在任何终端上显示并且进程也不会被任何终端所产生的终端信息所打断。
4.守护进程的创建包括六个基本过程:
a。umask(0):重设文件权限掩码
if(fork()<0) exit();
在Linux中父进程先于子进程退出会造成子进程成为孤儿进程,而每当系统发现一个孤儿进程时,就会自动由1号进程(init)收养它,这样,原先的子进程就会变成init进程的子进程。
c:创建新会话:
会话周期:会话期是一个或多个进程组的集合。通常,一个会话开始于用户登录,终止于用户退出,在此期间该用户运行的所有进程都属于这个会话期。
d:更改目录为根目录,防止当前目录被卸载:chdir("/");
e:关闭所有文件描述符:同文件权限码一样,用fork函数新建的子进程会从父进程那里继承一些已经打开了的文件。这些被打开的文件可能永远不会被守护进程读写,但它们一样消耗系统资源,而且可能导致所在的文件系统无法卸下。
for(i=0;i<getdtablesize();i++)
{
close(i);
}
f:int fd0,fd1,fd2;
fd0=open("/dev/null",O_RDWR);
fd1=dup(fd0);
fd2=dup(fd1);
这个操作是为 防止0,1,2的文件操作符被使用。0是标准输入,1是标准输出,2是标准出错。一旦被占用,文件内容会出错。
实验:
/*
============================================================================
Name : proteprocess.c
Author :
Version :
Copyright : Your copyright notice
Description : Hello World in C, Ansi-style
============================================================================
*/
//实验目的:主程序每隔一分钟
#include <stdio.h>
#include <stdlib.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<unistd.h>
#include<fcntl.h>
void init_doeman(void)
{
umask(0);
int i,fd0,fd1,fd2;
if(fork()<0)
exit(0);
setsid();
chdir("/");
for(i=0;i<getdtablesize();i++)
{
close(i);
}
fd0=open("/dev/null",O_RDWR);
fd1=dup(fd0);
fd2=dup(fd1);
//exit(0);
}
int main(void)
{
FILE *fp;
time_t t;
init_doeman();
while(1)
{
sleep(2);//每隔两秒钟报告一下运行状态
if((fp=fopen("test.log","a"))!=NULL)
{
t=time(0);
fprintf(fp,"I am here at %s/n",asctime(localtime(&t)));
fclose(fp);
}
}
return EXIT_SUCCESS;
}
401

被折叠的 条评论
为什么被折叠?



