昨天在Linux做個(gè)進(jìn)程守護(hù)腳本時(shí)發(fā)生了幾個(gè)小問(wèn)題,實(shí)屬不該。先總結(jié)如下,在以后的實(shí)踐中一個(gè)避免這樣的問(wèn)題。同時(shí)針對(duì)cron,再次深入學(xué)習(xí)實(shí)踐。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶,將通過(guò)不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名注冊(cè)、網(wǎng)絡(luò)空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、江蘇網(wǎng)站維護(hù)、網(wǎng)站推廣。
1、換行符問(wèn)題
腳本與運(yùn)行報(bào)錯(cuò)“:badinterpreter:Nosuchfileordirectory”。
腳本在windows下編輯,有幾條命令是直接復(fù)制過(guò)來(lái)使用的,雖然vs code可以在右下角選擇行尾序列,但是在實(shí)際運(yùn)行時(shí)還是提示無(wú)法識(shí)別/r,每一行都多了個(gè)^M? 。
\r\n: Dos和Windows采用回車+換行(CR+LF)表示下一行,即^M$
\n: 而UNIX/Linux采用換行符(LF)表示下一行
\r: 蘋果機(jī)(MAC OS系統(tǒng))則采用回車符(CR)表示下一行?
2、= 賦值問(wèn)題
筆者在使用if條件表達(dá)式時(shí),知道條件要放在方括號(hào)之間,并且要有空格。誤以為變量賦值=也要空格,運(yùn)行時(shí)發(fā)現(xiàn)變量無(wú)法識(shí)=識(shí)別,后來(lái)才知道變量賦值=不能有空格。
3、cron定時(shí)任務(wù)的環(huán)境變量問(wèn)題
用戶的crontab定時(shí)任務(wù)不會(huì)使用默認(rèn)的變量, 需要寫全路徑,包括crontab調(diào)用的腳本里面 。而系統(tǒng)cron定時(shí)任務(wù)是由定義環(huán)境變量的。MAILTO是表示例行性命令發(fā)生錯(cuò)誤時(shí),會(huì)將錯(cuò)誤訊息郵件傳給root,服務(wù)器中關(guān)閉postfix,導(dǎo)致郵件發(fā)送不成功,全部小文件堆積在/var/spool/postfix/maildrop/里面。
4、cron中執(zhí)行的程序有輸出內(nèi)容,輸出內(nèi)容會(huì)以郵件形式發(fā)給cron的用戶,而sendmail沒(méi)有啟動(dòng)所以就產(chǎn)生了/var/spool/mail目錄下的那些文件,日積月累可能撐破磁盤。在cron中命令后面加上 /dev/null 21 來(lái)不輸出。
5、crontab中的指令需要root,配置/etc/sudoers文件來(lái)保證sudo可用,其實(shí)可用使用系統(tǒng)任務(wù)計(jì)劃,指定root來(lái)執(zhí)行即可。
最后,筆者專注于使用cron,現(xiàn)在在以前的文章(樹莓派上測(cè)試)- Linux crontab定時(shí)任務(wù)詳細(xì)分解 的基礎(chǔ)上,在騰訊云服務(wù)器centos上補(bǔ)充以下cron的知識(shí)。
用戶計(jì)劃任務(wù) :
1、crond時(shí)cron的守護(hù)進(jìn)程,crond是由多個(gè)配置文件和系統(tǒng)范圍內(nèi)的文件控制的,每個(gè)用戶對(duì)應(yīng)一個(gè)配置文件。crond守護(hù)進(jìn)程是cronie軟件的一部分。用戶的配置文件在/var/spool/cron/username。
2、crontab命令
crontab -e 編輯當(dāng)前用戶的定時(shí)計(jì)劃
crontab -l 列出當(dāng)前用戶的定時(shí)計(jì)劃
?crontab -r 刪除當(dāng)前用戶的所有定時(shí)計(jì)劃
??crontab filename 刪除當(dāng)前用戶的所有定時(shí)計(jì)劃,并從filename中讀取作業(yè),如果未指定任何文件,則使用stdin 。
3、格式,另外*/x表示間隔x個(gè)周期。 用戶計(jì)劃任務(wù)沒(méi)有user-name字段!
*/7? 9-16? *? jul 5 command表示7月的每周五的上午9到下午5點(diǎn)?間,每七分鐘執(zhí)行一次。
系統(tǒng)計(jì)劃任務(wù):
1、系統(tǒng)cron不是由crontab來(lái)執(zhí)行的,而是在一組配置文件中定義的,配置文件多了一個(gè)字段-用戶字段,指定作業(yè)在那個(gè)用戶下運(yùn)行。
2、系統(tǒng)計(jì)劃任務(wù)儲(chǔ)存在/etc/crontab、 /etc/cron.d/*? 以及/etc/cron.* ,/etc/crontab的語(yǔ)法規(guī)則參照上面的圖。?/etc/cron.d/時(shí)軟件產(chǎn)生的一些更新任務(wù),一般不在里面做操作。
3、預(yù)定義作業(yè),cron.daily、cron.hourly、cron.monthly、cron.weekly下面儲(chǔ)存的是可執(zhí)行腳本。
/etc/cron.hourly/*腳本是使用runparts命令從/etc/cron.d/0hourly中定義的,表示每小時(shí)的第一分鐘將?/etc/cron.hourly/下面的腳本全部執(zhí)行。
/etc/cron.daily、?/etc/cron.monthly、?/etc/cron.weekly也是使用runparts命令,但是是從/etc/anacrontab中執(zhí)行的。
4、/etc/anacrontab語(yǔ)法規(guī)則
? ?START_HOURS_RANGE=3-22,表示Anacron jobs will start between 3am and 10pm.
? ?RANDOM_DELAY=45,The RANDOM_DELAY variable denotes the maximum number of minutes that will be added to the delay in minutes variable? which? is specified for each job.
?上圖中,對(duì)于?/etc/cron.daily,那么delay 會(huì)是 5 minutes + RANDOM_DELAY? 。
接下來(lái)就是4個(gè)重要的參數(shù):
? period in days ,delay in minutes ,job-identifier,? ?command
The period in days variable表示執(zhí)行周期,每多少天運(yùn)行一次該作業(yè)。
delay in minutes:上面提到的執(zhí)行的延時(shí),啟動(dòng)作業(yè)前,crond等待的時(shí)間。
job-identifier:標(biāo)識(shí)作業(yè)的唯一名稱,用做日志記錄。是/var/spool/anacron中文件的名稱,檢查該作業(yè)是否已運(yùn)行,/etc/anacrontab啟動(dòng)作業(yè)時(shí),會(huì)更新此文件的時(shí)間戳,檢查作業(yè)上次運(yùn)行的時(shí)間。anacron 會(huì)分析現(xiàn)在的時(shí)間與時(shí)間記錄文件所記載的上次執(zhí)行 anacron 的時(shí)間,將兩者進(jìn)行比較,如果兩個(gè)時(shí)間的差值超過(guò) anacron 的指定時(shí)間差值(一般是 1 天、7 天和一個(gè)月),就說(shuō)明有定時(shí)任務(wù)沒(méi)有執(zhí)行,這時(shí) anacron 會(huì)介入并執(zhí)行這個(gè)漏掉的定時(shí)任務(wù),從而保證在關(guān)機(jī)時(shí)沒(méi)有執(zhí)行的定時(shí)任務(wù)不會(huì)被漏掉。這也是為什么/etc/cron.{daily,weekly,monthly} 目錄中的定時(shí)任務(wù)只會(huì)被 anacron 調(diào)用,而?/etc/cron.hourly/被cron調(diào)用 。
command:執(zhí)行命令可以是普通命令或者腳本。
5、cron的訪問(wèn)控制
/etc/cron.allow、? ? /etc/cron.deny ,以決定哪些用戶可以使用調(diào)度服務(wù)。
如果只有cron.deny文件,而cron.allow文件不存在,則除了黑名單之外的所有用戶都可以使用;
如果只有cron.allow文件存在,而cron.deny文件不存在時(shí),則只有白名單用戶才可以使用,,包括root。
如果兩個(gè)文件都存在,則忽略cron.allow文件。
如果兩個(gè)文件都不存在,每個(gè)用戶都可以訪問(wèn)。
在Linux服務(wù)器實(shí)際應(yīng)用中,經(jīng)常會(huì)有需要長(zhǎng)時(shí)間執(zhí)行的任務(wù)。這類任務(wù)若在前臺(tái)運(yùn)行,用戶無(wú)法進(jìn)行其他操作或者斷開與服務(wù)器的連接,否則任務(wù)將被中止。此時(shí)適合使用守護(hù)進(jìn)程。為了使用守護(hù)進(jìn)程,需要了解Linux前臺(tái)、后臺(tái)、守護(hù)進(jìn)程的概念與使用,本文將對(duì)此進(jìn)行講解。
可以看出,”后臺(tái)任務(wù)”與”前臺(tái)任務(wù)”的重要區(qū)別: 是否繼承標(biāo)準(zhǔn)輸入 。所以,執(zhí)行后臺(tái)任務(wù)的同時(shí),用戶還可以輸入其他命令。
為了理解守護(hù)任務(wù)為何在結(jié)束session時(shí)也不退出,需要先了解Linux下退出session時(shí)發(fā)生的操作。
Session退出時(shí),linux系統(tǒng)設(shè)計(jì)如下:
前臺(tái)任務(wù)會(huì)隨著session的退出而退出是因?yàn)樗盏搅?SIGHUP信號(hào) 。
后臺(tái)任務(wù)是否會(huì)受到SIGNUP信號(hào),取決于shell的 huponexit 參數(shù)??梢酝ㄟ^(guò) $ shopt | grep huponexit 查看該參數(shù)的值。大多數(shù)Linux系統(tǒng),這個(gè)參數(shù)默認(rèn)關(guān)閉(off)。因此,session退出的時(shí)候,不會(huì)把SIGHUP信號(hào)發(fā)給”后臺(tái)任務(wù)”,即此時(shí)的后臺(tái)任務(wù)是守護(hù)進(jìn)程,但這顯然不夠安全。并不保險(xiǎn),因?yàn)橛械南到y(tǒng)的 huponexit 參數(shù)可能是打開的(on)狀態(tài)。
更保險(xiǎn)的方法是使用 disown命令。它可以將指定任務(wù)從”后臺(tái)任務(wù)”列表(jobs命令的返回結(jié)果)之中移除 。一個(gè)”后臺(tái)任務(wù)”只要不在這個(gè)列表之中,session 就肯定不會(huì)向它發(fā)出SIGHUP信號(hào)。
執(zhí)行上面的命令以后, server.js 進(jìn)程就被移出了”后臺(tái)任務(wù)”列表。你可以執(zhí)行 jobs 命令驗(yàn)證,輸出結(jié)果里面,不會(huì)有這個(gè)進(jìn)程。
但是,這樣還存在問(wèn)題。因?yàn)?”后臺(tái)任務(wù)”的標(biāo)準(zhǔn) I/O 繼承自當(dāng)前 session, disown 命令并沒(méi)有改變這一點(diǎn) 。一旦”后臺(tái)任務(wù)”讀寫標(biāo)準(zhǔn) I/O,就會(huì)發(fā)現(xiàn)它已經(jīng)不存在了,所以就 報(bào)錯(cuò)終止執(zhí)行 。 為了解決這個(gè)問(wèn)題,需要對(duì)”后臺(tái)任務(wù)”的 標(biāo)準(zhǔn) I/O 進(jìn)行重定向 。
這樣基本上就沒(méi)有問(wèn)題了。
注:
/dev/null 文件的作用
這是一個(gè)無(wú)底洞,任何東西都可以定向到這里,但是卻無(wú)法打開。
所以一般很大的stdou和stderr當(dāng)你不關(guān)心的時(shí)候可以利用stdout和stderr定向到這里
nohup命令對(duì)server.js進(jìn)程做了三件事。
阻止SIGHUP信號(hào)發(fā)到這個(gè)進(jìn)程。
關(guān)閉標(biāo)準(zhǔn)輸入。該進(jìn)程不再能夠接收任何輸入,即使運(yùn)行在前臺(tái)。
重定向標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)錯(cuò)誤到文件nohup.out。
也就是說(shuō),nohup命令實(shí)際上將子進(jìn)程與它所在的 session 分離了。 注意,nohup命令不會(huì)自動(dòng)把進(jìn)程變?yōu)椤焙笈_(tái)任務(wù)”,所以必須加上符號(hào)
守護(hù)進(jìn)程創(chuàng)建方法:
方法一:
方法二:
方法三:
fg、bg、jobs、、nohup、ctrl+z、ctrl+c 命令
一、
加在一個(gè)命令的最后,可以把這個(gè)命令放到后臺(tái)執(zhí)行,如:
二、ctrl + z
可以將一個(gè)正在前臺(tái)執(zhí)行的命令放到后臺(tái),并且處于暫停狀態(tài)。
CTRL+Z 和 CTRL+C的對(duì)比
CTRL+Z 和 CTRL+C 都是中斷命令,但是他們的作用卻不一樣.
CTRL+C 是強(qiáng)制中斷程序的執(zhí)行,而 CTRL+Z 的是將任務(wù)中斷,但是此任務(wù)并沒(méi)有結(jié)束,仍然在進(jìn)程中,只是維持掛起的狀態(tài),用戶可以使用 fg/bg 操作繼續(xù)前臺(tái)或后臺(tái)的任務(wù)。
三、jobs
查看當(dāng)前有多少在后臺(tái)運(yùn)行的進(jìn)程
jobs -l選項(xiàng)可顯示所有任務(wù)的PID,jobs的狀態(tài)可以是running, stopped, Terminated。但是如果任務(wù)被終止了(kill),shell 從當(dāng)前的shell環(huán)境已知的列表中刪除任務(wù)的進(jìn)程標(biāo)識(shí)。
四、fg
將后臺(tái)中的命令調(diào)至前臺(tái)繼續(xù)運(yùn)行。如果后臺(tái)中有多個(gè)命令,可以用 fg %jobnumber (jobnumber是命令編號(hào),不是進(jìn)程號(hào))將選中的命令調(diào)出。
五、bg
將一個(gè)在后臺(tái)暫停的命令,變成在后臺(tái)繼續(xù)執(zhí)行。
如果后臺(tái)中有多個(gè)命令,可以用 bg %jobnumber 將選中的命令調(diào)出。
六、kill
方法1:通過(guò)jobs命令查看job號(hào)(假設(shè)為num),然后執(zhí)行
方法2:通過(guò)ps命令查看job的進(jìn)程號(hào)(PID,假設(shè)為pid),然后執(zhí)行
前臺(tái)進(jìn)程的終止:Ctrl+c
七、nohup
如果想讓程序即使在關(guān)閉當(dāng)前的終端后也始終在后臺(tái)執(zhí)行(之前的做不到),需要使用nohup命令。
nohup命令可以在你退出帳戶/關(guān)閉終端之后繼續(xù)運(yùn)行相應(yīng)的進(jìn)程。
關(guān)閉終端后,在另一個(gè)終端jobs已經(jīng)無(wú)法看到后臺(tái)跑的程序了,此時(shí)利用ps(進(jìn)程查看命令)查看進(jìn)程。
建議使用supervisor,非常好用的守護(hù)工具,寫腳本不借助工具的話需要結(jié)合crontab,定期去ps -ef|grep 你的程序,做個(gè)判斷,如果不在了就執(zhí)行你的啟動(dòng)命令,supervisor之前我們使用的比較多,可以守護(hù)多個(gè)java程序,開源免費(fèi)。
查看守候進(jìn)程的命令可以使用ps完成。
進(jìn)程一般分為交互進(jìn)程、批處理進(jìn)程和守護(hù)進(jìn)程(daemons)三類。值得一提的是守護(hù)進(jìn)程總是活躍的,一般在后臺(tái)運(yùn)行,守護(hù)進(jìn)程一般由系統(tǒng)在開機(jī)時(shí)通過(guò)腳本自動(dòng)激活啟動(dòng)或由超級(jí)管理用戶root來(lái)啟動(dòng)。比如在Fedora或Redhat中,我們可以定義httpd服務(wù)器的啟動(dòng)腳本的運(yùn)行級(jí)別,此文件位于/etc/init.d目錄下,文件名是httpd,/etc/init.d/httpd 就是httpd服務(wù)器的守護(hù)程序,當(dāng)把它的運(yùn)行級(jí)別設(shè)置為3和5時(shí),當(dāng)系統(tǒng)啟動(dòng)時(shí),它會(huì)跟著啟動(dòng)。
[root@localhost?~]#?chkconfig?--level?35?httpd?on
由于守護(hù)進(jìn)程是一直運(yùn)行著的,所以它所處的狀態(tài)是等待請(qǐng)求處理任務(wù)。例如通常大網(wǎng)站的Apache服務(wù)器都在運(yùn)行,等待著用戶來(lái)訪問(wèn),也就是等待著任務(wù)處理。
Linux服務(wù)器在啟動(dòng)時(shí)需要啟動(dòng)很多系統(tǒng)服務(wù),它們向本地和網(wǎng)絡(luò)用戶提供了Linux的系統(tǒng)功能接口,直接面向應(yīng)用程序和用戶。提供這些服務(wù)的程序是由運(yùn)行在后臺(tái)的守護(hù)進(jìn)程來(lái)執(zhí)行的。守護(hù)進(jìn)程是生存期長(zhǎng)的一種進(jìn)程。它們獨(dú)立于控制終端并且周期性地執(zhí)行某種任務(wù)或等待處理某些發(fā)生的事件。它們常常在系統(tǒng)引導(dǎo)裝入時(shí)啟動(dòng),在系統(tǒng)關(guān)閉時(shí)終止。Linux系統(tǒng)有很多守護(hù)進(jìn)程,大多數(shù)服務(wù)器都是用守護(hù)進(jìn)程實(shí)現(xiàn)的。同時(shí),守護(hù)進(jìn)程完成許多系統(tǒng)任務(wù),比如,作業(yè)規(guī)劃進(jìn)程crond、打印進(jìn)程lqd等。有些書籍和資料也把守護(hù)進(jìn)程稱為"服務(wù)"。選擇運(yùn)行哪些守護(hù)進(jìn)程,要根據(jù)具體需求決定。查看系統(tǒng)可以提供的守護(hù)進(jìn)程對(duì)應(yīng)的服務(wù),打開一個(gè)終端以root權(quán)限運(yùn)行ntsysv命令。
守護(hù)進(jìn)程daemon,是生存期較長(zhǎng)的一種進(jìn)程。它們常常在系統(tǒng)自舉時(shí)啟動(dòng),僅在系統(tǒng)關(guān)閉時(shí)才終止。因?yàn)樗鼈儧](méi)有控制終端,所以說(shuō)它們是在后臺(tái)運(yùn)行的。UNIX系統(tǒng)有很多守護(hù)進(jìn)程,它們執(zhí)行日常事務(wù)活動(dòng)。
1、系統(tǒng)自舉
自舉(bootstrapping)一詞來(lái)自于人都是靠自身的自舉機(jī)構(gòu)站立起來(lái)的這一思想。計(jì)算機(jī)必須具備自舉能力將自己所有的元件激活,以便能完成加載操作系統(tǒng)這一目的,然后再由操作系統(tǒng)承擔(dān)起那些單靠自舉代碼無(wú)法完成的更復(fù)雜的任務(wù)。
自舉只有兩個(gè)功能:加電自檢和磁盤引導(dǎo)。
加電自檢:當(dāng)我們按下計(jì)算機(jī)電源開關(guān)時(shí),頭幾秒鐘機(jī)器似乎什么反應(yīng)也沒(méi)有,其實(shí),這時(shí)的計(jì)算機(jī)正在進(jìn)行加電自檢,以斷定它的所有元件都在正確地工作。如果某個(gè)元件有故障,顯示器上就會(huì)出現(xiàn)報(bào)警提示信息(如果顯示器也不能正常工作,則以一串嘟嘟聲來(lái)報(bào)警)。由于大多數(shù)計(jì)算機(jī)工作非??煽?,加電自檢報(bào)警非常罕見。
磁盤引導(dǎo):查找裝有操作系統(tǒng)的磁盤驅(qū)動(dòng)器。從磁盤加載操作系統(tǒng)的原因有二,一是操作系統(tǒng)升級(jí)簡(jiǎn)單容易,二是使用戶擁有選擇操作系統(tǒng)的自由。
當(dāng)加電自檢和磁盤引導(dǎo)完成時(shí),自舉操作就啟動(dòng)一個(gè)讀寫操作系統(tǒng)文件和將它們復(fù)制到隨機(jī)存儲(chǔ)器中的過(guò)程,此時(shí)的機(jī)器才是真正意義上的計(jì)算機(jī)。計(jì)算機(jī)的啟動(dòng)可以有冷啟動(dòng)和熱啟動(dòng)兩種方式 ,它們之間的差別是熱啟動(dòng)不進(jìn)行機(jī)器的自檢(機(jī)器本身配置的檢查與測(cè)試),當(dāng)計(jì)算機(jī)在使用過(guò)程中由于某些原因造成死機(jī)時(shí),可以對(duì)計(jì)算機(jī)進(jìn)行熱啟動(dòng)處理。
2、守護(hù)進(jìn)程的概念
通過(guò)ps axj命令可以查看到守護(hù)進(jìn)程:
參數(shù)a表示不僅列當(dāng)前用戶的進(jìn)程,也列出所有其他用戶的進(jìn)程,參數(shù)x表示不僅列有控制終端的進(jìn)程,也列出所有無(wú)控制終端的進(jìn)程,參數(shù)j表示列出與作業(yè)控制相關(guān)的信息。
代碼如下:PPID PID PGID SID TTY TPGID STAT UID TIME COMMAND 0 1 1 1 ? -1 Ss 0 0:01 /sbin/init 0 2 0 0 ? -1 S 0 0:00 [kthreadd] 2 3 0 0 ? -1 S 0 0:00 [migration/0] 2 4 0 0 ? -1 S 0 0:00 [ksoftirqd/0]... 1 2373 2373 2373 ? -1 Ss 0 0:00 /sbin/udevd --daemon... 1 4680 4680 4680 ? -1 Ss 0 0:00 /usr/sbin/acpid -c /etc... 1 4808 4808 4808 ? -1 Ss 102 0:00 /sbin/syslogd -u syslog...
凡是TPGID一欄寫著-1的都是沒(méi)有控制終端的進(jìn)程,也就是守護(hù)進(jìn)程。在COMMAND一列用[]括起來(lái)的名字表示內(nèi)核線程,這些線程在內(nèi)核里創(chuàng)建,沒(méi)有用戶空間代碼,因此沒(méi)有程序文件名和命令行,通常采用以k開頭的名字,表示Kernel。init進(jìn)程我們已經(jīng)很熟悉了,udevd負(fù)責(zé)維護(hù)/dev目錄下的設(shè)備文件,acpid負(fù)責(zé)電源管理,syslogd負(fù)責(zé)維護(hù)/var/log下的日志文件,可以看出,守護(hù)進(jìn)程通常采用以d結(jié)尾的`名字,表示Daemon。 創(chuàng)建守護(hù)進(jìn)程最關(guān)鍵的一步是調(diào)用setsid函數(shù)創(chuàng)建一個(gè)新的Session,并成為Session Leader。 例子: C/C++ Code復(fù)制內(nèi)容到剪貼板 void daemonize(void) { pid_t pid; printf("into deamonizen"); if (pid=fork() 0) { perror("fork"); exit(1); } else if (pid !=0) { exit(0); } setsid(); if (chdir("/") 0) { perror("chdir"); exit(1); } close(0); open("/dev/null", O_RDWR); dup2(0, 1); dup2(0, 2); printf("out deamonizen"); }
3、編寫守護(hù)進(jìn)程 在編寫守護(hù)進(jìn)程程序時(shí),需遵循一些基本規(guī)則:
(1)首先要做的是調(diào)用umask將文件模式創(chuàng)建屏蔽字設(shè)置為0。
(2)調(diào)用fork,然后使父進(jìn)程退出。
(3)調(diào)用setsid以創(chuàng)建一個(gè)新會(huì)話。
(4)將當(dāng)前工作目錄更改為根目錄。
(5)關(guān)閉不再需要的文件描述符。
(6)某些守護(hù)進(jìn)程打開/dev/null使其具有文件描述符0、1和2,任何一個(gè)試圖讀標(biāo)準(zhǔn)輸入、寫標(biāo)準(zhǔn)輸出或標(biāo)準(zhǔn)出錯(cuò)的庫(kù)例程都不會(huì)產(chǎn)生任何效果。 與守護(hù)進(jìn)程有關(guān)的一個(gè)問(wèn)題是如何處理出錯(cuò)消息,需要有一個(gè)集中的守護(hù)進(jìn)程出錯(cuò)記錄設(shè)施,這就是syslogd進(jìn)程。
4、守護(hù)進(jìn)程慣例 為了正常運(yùn)作,某些守護(hù)進(jìn)程實(shí)現(xiàn)為單實(shí)例的,有就是在任一時(shí)刻只運(yùn)行該守護(hù)進(jìn)程的一個(gè)副本。文件鎖和記錄鎖機(jī)制是一種方法的基礎(chǔ),該方法用來(lái)保證一個(gè)守護(hù)進(jìn)程只有一個(gè)副本在運(yùn)行。
在UNIX系統(tǒng)中,守護(hù)進(jìn)程遵循下列公共慣例:
(1)若守護(hù)進(jìn)程使用鎖文件,那么該文件通常存放在/var/run目錄中。鎖文件的名字通常是name.pid,name是該守護(hù)進(jìn)程或服務(wù)的名字。
(2)若守護(hù)進(jìn)程支持配置選項(xiàng),那么配置文件通常存放在/etc目錄中。配置文件的名字通常是name.conf。
(3)守護(hù)進(jìn)程可用命令行啟動(dòng),但通常它們是由系統(tǒng)初始化腳本啟動(dòng)的。
(4)若一守護(hù)進(jìn)程有一配置文件,那么當(dāng)該守護(hù)進(jìn)程啟動(dòng)時(shí),它讀該文件,但在此之后一般就不會(huì)再查看它。