<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0">
<channel>
<title><![CDATA[向东博客 专注WEB应用 构架之美 --- 构架之美，在于尽态极妍 | 应用之美，在于药到病除]]></title> 
<link>http://jackxiang.com/index.php</link> 
<description><![CDATA[赢在IT，Playin' with IT,Focus on Killer Application,Marketing Meets Technology.]]></description> 
<language>zh-cn</language> 
<copyright><![CDATA[向东博客 专注WEB应用 构架之美 --- 构架之美，在于尽态极妍 | 应用之美，在于药到病除]]></copyright>
<item>
<link>http://jackxiang.com/post//</link>
<title><![CDATA[编写Linux系统下Daemon程序的方法步骤--suse下编译通过]]></title> 
<author>jack &lt;xdy108@126.com&gt;</author>
<category><![CDATA[WEB2.0]]></category>
<pubDate>Tue, 30 Nov 2010 03:37:09 +0000</pubDate> 
<guid>http://jackxiang.com/post//</guid> 
<description>
<![CDATA[ 
	一、引言 Daemon程序是一直运行的服务端程序，又称为守护进程。<br/>本文介绍了在Linux下编写Daemon程序的步骤，并给出了例子程序。<br/>二、Daemon程序简介 Daemon是长时间运行的进程，通常在系统启动后就运行，在系统关闭时才结束。一般说Daemon程序在后台运行，是因为它没有控制终端，无法和前台的用户交互。Daemon程序一般都作为服务程序使用，等待客户端程序与它通信。我们也把运行的Daemon程序称作守护进程。<br/>三、Daemon程序编写规则<br/>编写Daemon程序有一些基本的规则，以避免不必要的麻烦。<br/>1、首先是程序运行后调用fork，并让父进程退出。子进程获得一个新的进程ID，但继承了父进程的进程组ID。<br/>2、调用setsid创建一个新的session，使自己成为新session和新进程组的leader，并使进程没有控制终端(tty)。<br/>3、改变当前工作目录至根目录，以免影响可加载文件系统。或者也可以改变到某些特定的目录。<br/>4、设置文件创建mask为0，避免创建文件时权限的影响。<br/>5、关闭不需要的打开文件描述符。因为Daemon程序在后台执行，不需要于终端交互，通常就关闭STDIN、STDOUT和STDERR。其它根据实际情况处理。<br/>另一个问题是Daemon程序不能和终端交互，也就无法使用printf方法输出信息了。我们可以使用syslog机制来实现信息的输出，方便程序的调试。在使用syslog前需要首先启动syslogd程序，关于syslogd程序的使用请参考它的man page，或相关文档，我们就不在这里讨论了。<br/>四、一个Daemon程序的例子 编译运行环境为Redhat Linux 8.0。<br/>我们新建一个daemontest.c程序，文件内容如下： <br/><br/><div class="code">#include &lt;unistd.h&gt;<br/>#include &lt;sys/types.h&gt;<br/>#include &lt;sys/stat.h&gt;<br/>#include &lt;stdlib.h&gt;<br/>#include &lt;stdio.h&gt;<br/>#include &lt;syslog.h&gt;<br/>#include &lt;signal.h&gt;<br/>int daemon_init(void)<br/>&#123; <br/>&nbsp;&nbsp;&nbsp;&nbsp;pid_t pid;<br/>&nbsp;&nbsp;&nbsp;&nbsp;if((pid = fork()) &lt; 0) return(-1);<br/>&nbsp;&nbsp;&nbsp;&nbsp;else if(pid != 0) exit(0); /* parent exit */<br/>&nbsp;&nbsp;&nbsp;&nbsp;/* child continues */<br/>&nbsp;&nbsp;&nbsp;&nbsp;setsid(); /* become session leader */<br/>&nbsp;&nbsp;&nbsp;&nbsp;chdir(&quot;/&quot;); /* change working directory */<br/>&nbsp;&nbsp;&nbsp;&nbsp;umask(0); /* clear file mode creation mask */<br/>&nbsp;&nbsp;&nbsp;&nbsp;close(0); /* close stdin */<br/>&nbsp;&nbsp;&nbsp;&nbsp;close(1); /* close stdout */<br/>&nbsp;&nbsp;&nbsp;&nbsp;close(2); /* close stderr */<br/>&nbsp;&nbsp;&nbsp;&nbsp;return(0); <br/>&#125;<br/>void sig_term(int signo)<br/>&#123; <br/>&nbsp;&nbsp;&nbsp;&nbsp;if(signo == SIGTERM)<br/>&nbsp;&nbsp;&nbsp;&nbsp;/* catched signal sent by kill(1) command */<br/>&nbsp;&nbsp;&nbsp;&nbsp;&#123; <br/>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;syslog(LOG_INFO, &quot;program terminated.&quot;);<br/>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;closelog(); exit(0); <br/>&nbsp;&nbsp;&nbsp;&nbsp;&#125;<br/>&#125;<br/>int main(void)<br/>&#123; <br/>&nbsp;&nbsp;&nbsp;&nbsp;if(daemon_init() == -1)<br/>&nbsp;&nbsp;&nbsp;&nbsp;&#123; <br/>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;printf(&quot;can&#039;t fork self&#92;n&quot;); exit(0); <br/>&nbsp;&nbsp;&nbsp;&nbsp;&#125;<br/>&nbsp;&nbsp;&nbsp;&nbsp;openlog(&quot;daemontest&quot;, LOG_PID, LOG_USER);<br/>&nbsp;&nbsp;&nbsp;&nbsp;syslog(LOG_INFO, &quot;program started.&quot;);<br/>&nbsp;&nbsp;&nbsp;&nbsp;signal(SIGTERM, sig_term); /* arrange to catch the signal */<br/>&nbsp;&nbsp;&nbsp;&nbsp;while(1) &#123; sleep(1); /* put your main program here */ &#125;<br/>&nbsp;&nbsp;&nbsp;&nbsp;return(0); <br/>&#125;</div><br/>使用如下命令编译该程序： gcc -Wall -o daemontest daemontest.c编译完成后生成名为daemontest的程序，执行./daemontest来测试程序的运行。<br/>使用ps axj命令可以显示系统中已运行的daemon程序的信息，包括进程ID、session ID、控制终端等内容。<br/>部分显示内容：<br/>PPID PID PGID SID TTY TPGID STAT UID TIME COMMAND<br/>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<br/>ps axj 从中可以看到daemontest程序运行的进程号为1650。<br/>我们再来看看/var/log/messages文件中的信息： Apr 7 22:00:32 localhost<br/>daemontest[1650]: program started.<br/>显示了我们在程序中希望输出的信息。<br/>我们再使用kill 1650命令来杀死这个进程，/var/log/messages文件中就会有如下的信息：<br/>Apr 7 22:11:10 localhost daemontest[1650]: program terminated.<br/>使用ps axj命令检查，发现系统中daemontest进程已经没有了。<br/>五、参考资料<br/>Advanced Programming in the Unix Environment W.Richard Stevens <br/>来源：http://www.q.cc/2007/04/27/10980.html
]]>
</description>
</item><item>
<link>http://jackxiang.com/post//#blogcomment</link>
<title><![CDATA[[评论] 编写Linux系统下Daemon程序的方法步骤--suse下编译通过]]></title> 
<author> &lt;user@domain.com&gt;</author>
<category><![CDATA[评论]]></category>
<pubDate>Thu, 01 Jan 1970 00:00:00 +0000</pubDate> 
<guid>http://jackxiang.com/post//#blogcomment</guid> 
<description>
<![CDATA[ 
	
]]>
</description>
</item>
</channel>
</rss>