守护进程。通常在系统后台运行,没有控制终端不与前台交互,Daemon程序一般作为系统服务使用。Daemon是长时间运行的进程,通常在系统启动后就运行,在系统关闭时才结束。一般说Daemon程序在后台运行,是因为它没有控制终端,无法和前台的用户交互。Daemon程序一般都作为服务程序使用,等待客户端程序与它通信。我们也把运行的Daemon程序称作守护进程。
]]>
Daemon程序实现方法编辑
编写Daemon程序有一些基本的规则,以避免不必要的麻烦。
2、调用setsid创建一个新的session,使自己成为新session和新进程组的leader,并使进程没有控制终端(tty)。
3、改变当前工作目录至根目录,以免影响可加载文件系统。或者也可以改变到某些特定的目录。
4、设置文件创建mask为0,避免创建文件时权限的影响。
另一个问题是Daemon程序不能和终端交互,也就无法使用printf方法输出信息了。我们可以使用syslog机制来实现信息的输出,方便程序的调试。在使用syslog前需要首先启动syslogd程序,关于syslogd程序的使用请参考它的man page,或相关文档,我们就不在这里讨论了。
Daemon程序实现例子编辑
一个Daemon程序的例子 编译运行环境为Redhat Linux 8.0。
我们新建一个daemontest.c程序,文件内容如下:
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 |
#include #include #include #include #include #include #include intdaemon_init( void ) { pid_tpid; if ((pid=fork())<0) return (-1); elseif(pid!=0) exit (0); /*parentexit*/ /*childcontinues*/ setsid(); /*becomesessionleader*/ chdir( "/" ); /*changeworkingdirectory*/ umask(0); /*clearfilemodecreationmask*/ close(0); /*closestdin*/ close(1); /*closestdout*/ close(2); /*closestderr*/ return (0); } voidsig_term(intsigno) { if (signo==SIGTERM) /*catchedsignalsentbykill(1)command*/ { syslog(LOG_INFO, "programterminated." ); closelog(); exit (0); } } intmain( void ) { if (daemon_init()==-1) { printf ( "can'tforkself\n" ); exit (0); } openlog( "daemontest" ,LOG_PID,LOG_USER); syslog(LOG_INFO, "programstarted." ); signal (SIGTERM,sig_term); /*arrangetocatchthesignal*/ while (1) { sleep(1); /*putyourmainprogramhere*/ } return (0); } |
使用如下命令编译该程序: gcc -Wall -o daemontest daemontest.c编译完成后生成名为daemontest的程序,执行./daemontest来测试程序的运行。
使用ps axj命令可以显示系统中已运行的daemon程序的信息,包括进程ID、session ID、控制终端等内容。
部分显示内容:
PPID PID PGID SID TTY TPGID STAT UID TIME COMMAND
1098 1101 1101 1074 pts/1 1101 S 0 0:00 -bash 1 1581 777 777 ? -1 S 500 0:13 gedit 1 1650 1650 1650 ? -1 S 500 0:00 ./daemontest 794 1654 1654 794 pts/0 1654 R 500 0:00
ps axj 从中可以看到daemontest程序运行的进程号为1650。
我们再来看看/var/log/messages文件中的信息: Apr 7 22:00:32 localhost
daemontest[1650]: program started.
我们再使用kill 1650命令来杀死这个进程,/var/log/messages文件中就会有如下的信息:
Apr 7 22:11:10 localhost daemontest[1650]: program terminated.
使用ps axj命令检查,发现系统中daemontest进程已经没有了。
词条标签:
评论区