歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux綜合 >> Linux資訊 >> Linux文化 >> 在Linux下編寫Daemon程序的步驟及例子程序

在Linux下編寫Daemon程序的步驟及例子程序

日期:2017/2/27 11:51:32   编辑:Linux文化

一、引言 Daemon程序是一直運行的服務端程序,又稱為守護進程。

本文介紹了在Linux下編寫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 #include #include #include #include #include #include

int daemon_init(void) { pid_t pid; if((pid = fork()) < 0) return(-1); else if(pid != 0) exit(0); /* parent exit */ /* child continues */ setsid(); /* become session leader */ chdir("/"); /* change working directory */ umask(0); /* clear file mode creation mask */ close(0); /* close stdin */ close(1); /* close stdout */ close(2); /* close stderr */ return(0); } void sig_term(int signo) { if(signo == SIGTERM) /* catched signal sent by kill(1) command */ { syslog(LOG_INFO, "program terminated."); closelog(); exit(0); } } int main(void) { if(daemon_init() == -1) { printf("can't fork self\n"); exit(0); } openlog("daemontest", LOG_PID, LOG_USER); syslog(LOG_INFO, "program started."); signal(SIGTERM, sig_term); /* arrange to catch the signal */ while(1) { sleep(1); /* put your main program here */ } 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進程已經沒有了。

五、參考資料

Advanced Programming in the UNIX Environment W.Richard Stevens


Copyright © Linux教程網 All Rights Reserved