新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 進程控制開發之:Linux守護進程

        進程控制開發之:Linux守護進程

        作者: 時間:2013-09-13 來源:網絡 收藏

        本文引用地址:http://www.104case.com/article/257130.htm

        (2)setsid()函數格式。

        表7.8列出了setsid()函數的語法規范。

        表7.8 setsid()函數語法

        所需頭文件

        #includesys/types.h>
        #includeunistd.h>

        函數原型

        pid_tsetsid(void)

        函數返回值

        成功:該進程組ID
        出錯:-1

        3.改變當前目錄為根目錄

        這一步也是必要的步驟。使用fork()創建的繼承了父進程的當前工作目錄。由于在進程運行過程中,當前目錄所在的文件系統(比如“/mnt/usb”等)是不能卸載的,這對以后的使用會造成諸多的麻煩(比如系統由于某種原因要進入單用戶模式)。因此,通常的做法是讓“/”作為的當前工作目錄,這樣就可以避免上述的問題,當然,如有特殊需要,也可以把當前工作目錄換成其他的路徑,如/tmp。改變工作目錄的常見函數是chdir()。

        4.重設文件權限掩碼

        文件權限掩碼是指屏蔽掉文件權限中的對應位。比如,有一個文件權限掩碼是050,它就屏蔽了文件組擁有者的可讀與可執行權限。由于使用fork()函數新建的繼承了父進程的文件權限掩碼,這就給該使用文件帶來了諸多的麻煩。因此,把文件權限掩碼設置為0,可以大大增強該的靈活性。設置文件權限掩碼的函數是umask()。在這里,通常的使用方法為umask(0)。

        5.關閉文件描述符

        同文件權限掩碼一樣,用fork()函數新建的子進程會從父進程那里繼承一些已經打開了的文件。這些被打開的文件可能永遠不會被讀或寫,但它們一樣消耗系統資源,而且可能導致所在的文件系統無法被卸載。

        在上面的第二步之后,守護進程已經與所屬的控制終端失去了聯系。因此從終端輸入的字符不可能達到守護進程,守護進程中用常規方法(如printf())輸出的字符也不可能在終端上顯示出來。所以,文件描述符為0、1和2的3個文件(常說的輸入、輸出和報錯這3個文件)已經失去了存在的價值,也應被關閉。通常按如下方式關閉文件描述符:

        for(i=0;iMAXFILE;i++)

        {

        close(i);

        }

        這樣,一個簡單的守護進程就建立起來了,創建守護進程的流程圖如圖7.7所示。

        創建守護進程流程圖

        下面是實現守護進程的一個完整實例,該實例首先按照以上的創建流程建立了一個守護進程,然后讓該守護進程每隔10s向日志文件/tmp/daemon.log寫入一句話。

        /*daemon.c創建守護進程實例*/

        #includestdio.h>

        #includestdlib.h>

        #includestring.h>

        #includefcntl.h>

        #includesys/types.h>

        #includeunistd.h>

        #includesys/wait.h>

        intmain()

        {

        pid_tpid;

        inti,fd;

        char*buf=ThisisaDaemonn;

        pid=fork();/*第一步*/

        if(pid0)

        {

        printf(Errorforkn);

        exit(1);

        }

        elseif(pid>0)

        {

        exit(0);/*父進程推出*/

        }

        setsid();/*第二步*/

        chdir(/);/*第三步*/

        umask(0);/*第四步*/

        for(i=0;igetdtablesize();i++)/*第五步*/

        {

        close(i);

        }

        /*這時創建完守護進程,以下開始正式進入守護進程工作*/

        while(1)

        {

        if((fd=open(/tmp/daemon.log,

        O_CREAT|O_WRONLY|O_APPEND,0600))0)

        {

        printf(Openfileerrorn);

        exit(1);

        }

        write(fd,buf,strlen(buf)+1);

        close(fd);

        sleep(10);

        }

        exit(0);

        }

        將該程序下載到開發板上,可以看到該程序每隔10s就會在對應的文件中輸入相關內容。并且使用ps可以看到該進程在后臺運行。如下所示:

        $tail-f/tmp/daemon.log

        ThisisaDaemon

        ThisisaDaemon

        ThisisaDaemon

        ThisisaDaemon

        $ps-ef|grepdaemon

        76root1272S./daemon

        85root1520Sgrepdaemon

        linux操作系統文章專題:linux操作系統詳解(linux不再難懂)

        pid控制相關文章:pid控制原理


        linux相關文章:linux教程


        pid控制器相關文章:pid控制器原理




        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 堆龙德庆县| 特克斯县| 聂拉木县| 南皮县| 洪湖市| 马边| 资阳市| 隆尧县| 鲁山县| 弥渡县| 突泉县| 元氏县| 手游| 城步| 抚松县| 溆浦县| 孙吴县| 宣城市| 长岭县| 金秀| 买车| 古蔺县| 台山市| 洞头县| 清苑县| 壤塘县| 东乌珠穆沁旗| 上杭县| 隆德县| 平顶山市| 二连浩特市| 视频| 含山县| 河北区| 宿州市| 华容县| 班戈县| 大港区| 乐亭县| 阿拉善左旗| 万安县|