linux daemon代码完全注释


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#include <unistd.h>
#include <signal.h>
#include <sys/param.h>
#include <sys/types.h>
#include <sys/stat.h>
 
void  init_daemon( void )
{        
     int  pid;        
     int  i;
     
     /*  when:step 1;
      *  what:将daemon放入后台运行;
      *  why:为避免挂起控制终端;
      *  how:在进程中调用fork使父进程终止,让daemon在子进程中后台运行。
      */
     if (pid=fork())
         exit (0); //是父进程,结束父进程
     else  if (pid< 0)
         exit (1); //fork失败,退出
         
         
     /* when:step 2。
      * what:脱离控制终端,登陆会话和进程组
      *  why:当进程是回话组长时setsid()会失败,step1已经确保进程不是会话组长
      *  how:在子进程中调用setsid()
      */
     setsid(); 
     
     //PS: 调用成功后进程成为新的会话组长和新的进程组组长,并和原来的登陆会话和进程组脱离,由于会话对控制终端的独占性,进程同时和控制终端脱离。
  
     
     /* when:step3;
      * what:禁止进程重新打开控制终端;
      * why :无终端的会话组长能够重新申请打开一个控制终端;
      * how :使进程不再是会话组长
     */
     
     if (pid=fork())
         exit (0); //是第一子进程,结束第一子进程
     else  if (pid< 0)
         exit (1); //fork失败,退出
     
     //PS:第一子进程即新会话组组长退出,第二子进程继续,但第二子进程不是新会话组组长
 
     
     /* when:step4;
      * what:关闭打开的文件描述符;
      * why :进程会从创建他的父进程那里继承打开的文件描述符,如不关闭,一方面会浪费系统资源,另一方便还会导致文             件无法删除文件系统无法卸载等无法预料的错误;
      * how :调用close()关闭打开的文件;
      */
     for (i=0; i< NOFILE; i++)
         close(i);
     
     
     /* when:step5;
      * what:改变当前工作目录;
      *  why:进程活动时,其工作目录所在的文件系统不能卸载
      *  how:一般需要调用chdir()将工作目录改变到根目录
     */
     chdir( "/" );
     
     
     /* when:step6;
      * what:重设文档创建掩码
      * why :进程冲创建他得父进程那里继承了文件创建掩码,他可能修改守护进程所创建的文件的读取权限
      * how :调用umask(0)清除文件创建掩码
     */
     umask(0);
     
     /* when:step7;
      * what:处理子进程结束信号SIGCHILD
      * why :防止子进程变成僵尸进程无法杀死,占用系统资源
      * how :在linux下忽略该信号即可
     */
     signal (SIGCHLD, SIG_IGN);
     
     return ;
     
}
 
 
example.c:
 
int  main( void )
{
     FILE  *fp = NULL;
     time_t  t;
     
     //初始化为daemon
     int_daemon();
     
     
/* 实际编程中建议使用 daemon(0, 0) */
     
//daemon(0, 0);
     
     while  (1){
         sleep(60);
         if  ((fp =  fopen ( "test.log" "a" )) > 0){
             t =  time (0);
             fprintf (fp,  "i'm here at %s\r\n" asctime ( localtime (&t)));
             fclose (fp);
         }
     }
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux守护进程(daemon)是在后台运行的一种进程,它不与任何终端或控制台交互,而是在系统启动时启动并一直运行,直到系统关闭。它通常用于执行一些系统级任务,如网络服务、日志记录、备份等。Linux守护进程的特点是稳定、可靠、高效,可以在不影响系统性能的情况下长时间运行。 ### 回答2: Linux中的守护进程(daemon)是一种在后台运行的特殊类型进程。与普通进程相比,守护进程没有终端依附,也没有用户交互界面。它通常在系统启动时自动启动,持续运行以提供特定的服务。 守护进程的一个重要特点是与特定任务相关联。例如,网络服务守护进程可以为网络请求提供响应,日志守护进程可以定期记录系统日志。同时,守护进程还可以执行系统维护、定时作业、资源监控等任务。 守护进程的实现基于fork()系统调用和一些特定的处理。当一个守护进程启动时,它会先调用fork()创建一个子进程,然后父进程退出,子进程成为守护进程并脱离终端。接下来,守护进程会改变当前工作目录、重设文件权限、关闭不需要的文件描述符、重定向标准输入输出等,以确保它可以无阻塞地运行。 由于守护进程主要在后台运行,所以它没有交互界面。一般情况下,守护进程使用配置文件来配置自身的行为,这些配置文件可以在运行时通过修改来进行调整。此外,守护进程通常会以系统日志的形式记录自己的运行状态,方便系统管理员进行故障排查和性能优化。 总的来说,Linux中的守护进程是为了提供特定服务或执行特定任务而设计的一种后台进程。它以无终端、无交互界面的方式运行,可以自动启动并持续提供服务。守护进程在系统管理中起到了至关重要的作用,为系统运行的稳定性和功能提供了有力的支持。 ### 回答3: Linux守护进程(daemon)是在后台运行的程序,它以无人值守的方式工作,不会与用户交互。守护进程在Linux系统中是非常常见的,用于执行系统任务、管理服务等。 Linux守护进程具有以下特点: 1. 后台运行:守护进程在后台运行,不占用用户的终端,并且不需要用户的干预。它通常作为服务或系统进程运行,负责在系统启动时启动、停止和管理其他进程。 2. 无人值守:守护进程在运行期间没有用户的输入,完全自主工作。它通常会周期性地执行任务或响应特定的事件,例如系统日志记录、定时任务的执行等。 3. 脱离终端:守护进程不会与用户的终端进行交互,没有标准输入或标准输出。这使得守护进程能够在后台运行,从而不受用户登录和注销的影响。 4. 无需用户干预:守护进程在执行期间不需要用户干预。它可以自主地调整自身的行为,根据需要进行启动、停止和配置其他进程。 5. 生命周期:守护进程在系统启动时自动启动,并在系统关闭时停止。它会一直保持运行,直到系统关机或管理员手动停止。 守护进程的典型应用包括Web服务器、数据库服务器、邮件服务器等。它们能够在后台稳定运行,提供服务并处理请求,为用户提供无干扰的服务。与用户交互的程序通常是通过与守护进程进行通信,将用户请求传递给相应的处理程序完成相应的操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值