本文,相关评论守护进程的主要定义和原则。并通过一个例子来说明如何编写用户守护进程。
1.守护进程的撰写条件:
1)D要在系统中处于一直运转的状态,也就是说while循环,时刻在监听服务2)D不能在关闭终端的时候退出—— 为什么终端关闭将导致进程退出呢?
3)D要脱离控制终端,登录会话和进程组—— 注销的时候,为什么有的进程将被注销。而有的不会?
2.相关原理
Q:每一个进程都属于一个进程组,就是进程组长的ID。一个登录会话能够包括多个进程组,这些进程组共享一个控制终端.他们的关系能够參考下图?
Q:为什么要设计进程组id?
A:(猜想)方便对作业进行管理,可能在某些时候我们须要对一组进程而不是一个进程进行管理;比如在一个终端发送信号,那么信号对全部属于这个终端的进程组都是有效的。
Q.tip:怎样查看一个进程组的进程组id?怎样查看控制终端?ps和top命令的每一个字段是什么意思?
ps 依照用户的要求输出全部相关的信息:ps axo stat,euid,ruid,tty,tpgid,sess,pgrp,ppid,pid,pcpu,comm
只查看进程组id:ps -C sshd -o pgrp
ps -p ID -o pgrp
Q:怎样得到进程的组id和设置进程的组id?
A:pid_t getpgrp() ;
int setpgid(pid_t pid, pid_t pgid) :进程能够调用这个函数来设置自己或者子进程的pgid
3.守护进程的编写步骤
守护进程的编写中,有两个基本的部分:1)脱离控制 2)清理资源守护进程编程步骤
1. 创建子进程,父进程退出
•全部工作在子进程中进行
•形式上脱离了控制终端
2. 在子进程中创建新会话
•setsid()函数
•使子进程全然独立出来,脱离控制
3. 改变当前文件夹为根文件夹
•chdir()函数
•防止占用可卸载的文件系统
•也能够换成其他路径
4. 重设文件权限掩码
•umask()函数:将某些文件权限标记为设定为0
•防止继承的文件创建屏蔽字拒绝某些权限
•添加守护进程灵活性
5. 关闭文件描写叙述符
•继承的打开文件不会用到,浪费系统资源。无法卸载
•getdtablesize()
•返回所在进程的文件描写叙述符表的项数,即该进程打开的文件数目
code:
#include "stdio.h" /* #include "type.h" */ #include <unistd.h> #include <fcntl.h> /* #include < sys/wait.h> */ #include <sys/types.h> #include <string.h> int main(int argc, char *argv[]) { pid_t pid; int i, fd; char *buf = "This is a deamon program"; if( (pid = fork()) < 0){ printf("fork error!"); exit(1); } else if(pid >0){ exit(0); } /* setsid(); */ chdir("/"); umask(0); for (int i = 0; i < getdtablesize(); ++i){ close(i); } while(1){ if( ( fd=open("/tmp/daemon.log", O_CREAT| O_WRONLY | O_APPEND, 0600)) < 0){ } write(fd, buf, strlen(buf)+1); close(fd); sleep(10); printf("never"); } return 0; }
版权声明:本文博主原创文章,博客,未经同意不得转载。
本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/4873570.html,如需转载请自行联系原作者