您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“Perl守護進程怎么用”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“Perl守護進程怎么用”這篇文章吧。
Perl守護進程
LinuxPerl守護進程的編程方法
Perl守護進程(Daemon)是運行在后臺的一種特殊進程。它獨立于控制終端并且周期性地執行某種任務或等待處理某些發生的事件。Perl守護進程是一種很有用的進程。Linux的大多數服務器就是用Perl守護進程實現的。比如,Internet服務器inetd,Web服務器httpd等。同時,Perl守護進程完成許多系統任務。比如,作業規劃進程crond,打印進程lpd等。
Perl守護進程的編程本身并不復雜,復雜的是各種版本的Unix的實現機制不盡相同,造成不同Unix環境下Perl守護進程的編程規則并不一致。這需要讀者注意,照搬某些書上的規則(特別是BSD4.3和低版本的SystemV)到Linux會出現錯誤的。下面將全面介紹Linux下Perl守護進程的編程要點并給出詳細實例。
一.Perl守護進程及其特性
Perl守護進程最重要的特性是后臺運行。在這一點上DOS下的常駐內存程序TSR與之相似。其次,Perl守護進程必須與其運行前的環境隔離開來。這些環境包括未關閉的文件描述符,控制終端,會話和進程組,工作目錄以及文件創建掩模等。這些環境通常是Perl守護進程從執行它的父進程(特別是shell)中繼承下來的。***,Perl守護進程的啟動方式有其特殊之處。它可以在Linux系統啟動時從啟動腳本/etc/rc.d中啟動,可以由作業規劃進程crond啟動,還可以由用戶終端(通常是shell)執行。
總之,除開這些特殊性以外,Perl守護進程與普通進程基本上沒有什么區別。因此,編寫Perl守護進程實際上是把一個普通進程按照上述的Perl守護進程的特性改造成為Perl守護進程。如果讀者對進程有比較深入的認識就更容易理解和編程了。
二、Perl守護進程實例
Perl守護進程實例包括兩部分:主程序test.c和初始化程序init.c。主程序每隔一分鐘向/tmp目錄中的日志test.log報告運行狀態。初始化程序中的init_daemon函數負責生成Perl守護進程。讀者可以利用init_daemon函數生成自己的Perl守護進程。
1.init.c清單
init.c#include<unistd.h> #include<signal.h> #include<sys/param.h> #include<sys/types.h> #include<sys/stat.h> voidinit_daemon(void) { intpid; inti; if(pid=fork()) exit(0);//是父進程,結束父進程 elseif(pid<0) exit(1);//fork失敗,退出 //是***子進程,后臺繼續執行 setsid();//***子進程成為新的會話組長和進程組長 //并與控制終端分離 if(pid=fork()) exit(0);//是***子進程,結束***子進程 elseif(pid<0) exit(1);//fork失敗,退出 //是第二子進程,繼續 //第二子進程不再是會話組長 for(i=0;i<NOFILE;++i)//關閉打開的文件描述符 close(i); chdir("/tmp");//改變工作目錄到/tmp umask(0);//重設文件創建掩模 return; }
2.test.c清單test.c#include<stdio.h>
#include<time.h> voidinit_daemon(void);//Perl守護進程初始化函數 main() { FILE*fp; time_tt; init_daemon();//初始化為Daemon while(1)//每隔一分鐘向test.log報告運行狀態 { sleep(60);//睡眠一分鐘 if((fp=fopen("test.log","a"))>=0) { t=time(0); fprintf(fp,"Imhereat%s\n",asctime(localtime(&t))); fclose(fp); } } }
以上程序在RedHatLinux6.0下編譯通過。步驟如下:
編譯:gcc-g-otestinit.ctest.c
執行:./test
查看進程:ps-ef
從輸出可以發現testPerl守護進程的各種特性滿足上面的要求。
以上是“Perl守護進程怎么用”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。