daemon()

daemon()

Daemon()程式是一直運行的服務端程式,又稱為守護進程。通常在系統後台運行,沒有控制終端,不與前台互動,Daemon程式一般作為系統服務使用。Daemon是長時間運行的進程,通常在系統啟動後就運行,在系統關閉時才結束。一般說Daemon程式在後台運行,是因為它沒有控制終端,無法和前台的用戶互動。Daemon程式一般都作為服務程式使用,等待客戶端程式與它通信。我們也把運行的Daemon程式稱作守護進程。

基本介紹

實現方法,例子,

實現方法

編寫Daemon程式有一些基本的規則,以避免不必要的麻煩。
1、首先是程式運行後調用fork,並讓父進程退出。子進程獲得一個新的進程ID,但繼承了父進程的進程組ID。
2、調用setsid創建一個新的session,使自己成為新session和新進程組的leader,並使進程沒有控制終端(tty)。
3、改變當前工作目錄至根目錄,以免影響可載入檔案系統。或者也可以改變到某些特定的目錄。
4、設定檔案創建mask為0,避免創建檔案時許可權的影響。
5、關閉不需要的打開檔案描述符。因為Daemon程式在後台執行,不需要於終端互動,通常就關閉STDIN、STDOUT和STDERR。其它根據實際情況處理。
另一個問題是Daemon程式不能和終端互動,也就無法使用printf方法輸出信息了。我們可以使用syslog機制來實現信息的輸出,方便程式的調試。在使用syslog前需要首先啟動syslogd程式,關於syslogd程式的使用請參考它的man page,或相關文檔,我們就不在這裡討論了。

例子

一個Daemon程式的例子 編譯運行環境為Redhat Linux 8.0。
我們新建一個daemontest.c程式,檔案內容如下:
#include<unistd.h>#include<sys/types.h>#include<sys/stat.h>#include<stdlib.h>#include<stdio.h>#include<syslog.h>#include<signal.h>int daemon_init(void){    pid_t pid;    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);}void sig_term(intsigno){    if(signo==SIGTERM)        /*catchedsignalsentbykill(1)command*/    {        syslog(LOG_INFO,"programterminated.");        closelog();        exit(0);    }}int main(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進程已經沒有了。

相關詞條

熱門詞條

聯絡我們