我們在linux主機上可能需要一直執行某一服務,如果關機後或者誤殺,使得服務停止,從而影響日常的任務。比如一bi專案資料庫的抽取,使用taskctl排程,在每天固定時間進行資料的抽取,如果主機上taskctl相關的服務程序被關閉的話,就會影響到資料的抽取!
linux下的任務排程分為兩類:系統任務排程和使用者任務排程。
系統任務排程:系統週期性所要執行的工作,比如寫快取資料到硬碟、日誌清理等。在/etc目錄下有乙個crontab檔案,這個就是系統任務排程的配置檔案。
/etc/crontab檔案包括下面幾行:
shell=/bin/bash
path=/sbin:/bin:/usr/sbin:/usr/bin
mailto=""home=/
# run-parts
51 * * * * root run-parts /etc/cron.hourly
24 7 * * * root run-parts /etc/cron.daily
22 4 * * 0 root run-parts /etc/cron.weekly 42 4 1 * * root run-parts /etc/cron.monthly
前四行是用來配置crond任務執行的環境變數,第一行shell變數指定了系統要使用哪個shell,這裡是bash,第二行path變數指定了系統執行命令的路徑,第三行mailto變數指定了crond的任務執行資訊將通過電子郵件傳送給root使用者,如果mailto變數的值為空,則表示不傳送任務執行資訊給使用者,第四行的home變數指定了在執行命令或者指令碼時使用的主目錄。
使用者任務排程:使用者定期要執行的工作,比如使用者資料備份、定時郵件提醒等。使用者可以使用 crontab 工具來定製自己的計畫任務。所有使用者定義的crontab檔案都被儲存在/var/spool/cron
目錄中。其檔名與使用者名稱一致,使用者許可權檔案如下:
/etc/cron.deny
該檔案中所列使用者不允許使用crontab命令
/etc/cron.allow
該檔案中所列使用者允許使用crontab命令
/var/spool/cron/
所有使用者crontab檔案存放的目錄,以使用者名稱命名
crontab -e
,然後就會有個vi編輯介面,再輸入一定格式的內容到裡面 :wq 儲存退出,即建立乙個定時任務。
該一定格式的內容包括六個域,其中前五個域是指定命令被執行的時間,最後乙個域是要被執行的命令。
每個域之間使用空格或者製表符分隔。格式如下:
對應的合法值00-59
,00-23
,01-31
,01-12
,0-6 (0 is sunday)
,commands(代表要執行的指令碼)
除了數字還有幾個特殊的符號就是星號"*"
、斜槓"/"
、中劃線"-"
、逗號","
。
*
代表所有的取值範圍內的數字,
/
代表每的意思,/5
表示每5個單位,
-
代表從某個數字到某個數字,
,
分開幾個離散的數字。
比如:0 0 * * * sh /home/sh/monitor.sh
,每天凌晨0點0分執行monitor.sh這個指令碼。
/sbin/service crond start //啟動服務
/sbin/service crond stop //關閉服務
/sbin/service crond restart //重啟服務
/sbin/service crond reload //重新載入配置
/sbin/service crond status //檢視服務狀態
檢視crontab服務是否已設定為開機啟動,執行命令:ntsysv
,此命令需要是root使用者。
加入開機自動啟動:chkconfig --level 5 crond on
之後檢視:chkconfig --list|grep crond
上邊說了定時任務,每天固定時間執行shell指令碼,那麼這個指令碼我們可以寫上監聽該服務程序的內容。
monitor.sh
這裡以taskctl相關服務為例:
#!/bin/sh
nowtime=$(date +%y%m%d_%h%m%s)
ps -fe|grep emnls|grep -v grep
if [ $? -ne 0 ]
then echo $nowtime" stopped.....">>/home/mars/checkprolog.txt eminit ctlinit ctlstart else echo $nowtime " running....." >>/home/mars/checkprolog.txt fi
其中,nowtime=$(date +%y%m%d_%h%m%s)
得到當前系統時間,沒有什麼好說的,注意date後邊有乙個空格!emnls
為taskctl核心服務程序名稱。$? -ne 0
不存在,$? -eq 0
存在。
shell的if else 語法以及大於,小於等邏輯表示式:
if ....
then
.... elif .... then .... else .... fi
大多數情況下,可以使用測試命令來對條件進行測試。比如可以比較字串、判斷檔案是否存在及是否可讀等等… 通常用」 [ ] 「來表示條件測試。注意這裡的空格很重要,要確保方括號的空格。
[ -f "somefile" ]
:判斷是否是乙個檔案
[ -x "/bin/ls" ]
:判斷/bin/ls
是否存在並有可執行許可權
[ -n "$var" ]
:判斷$var
變數是否有值
[ "$a" = "$b" ]
:判斷$a
和$b
是否相等
對乙個檔案的判斷:
-r file 使用者可讀為真
-w file 使用者可寫為真
-x file 使用者可執行為真
-f file 檔案為正規檔案為真
-d file 檔案為目錄為真 -c file 檔案為字元特殊檔案為真 -b file 檔案為塊特殊檔案為真 -s file 檔案大小非0時為真 -t file 當檔案描述符(預設為1)指定的裝置為終端時為真
對於不含變數的任務簡單shell指令碼一般能勝任。但在執行一些決策任務時,就需要包含if/then的條件判斷了。shell指令碼程式設計支援此類運算,包括比較運算、判斷檔案是否存在等。基本的if條件命令選項有:- eq —比較兩個引數是否相等
(例如,if [ 2 –eq 5 ])
-ne —比較兩個引數是否不相等
-lt —引數1是否小於引數2
-le —引數1是否小於等於引數2 -gt —引數1是否大於引數2 -ge —引數1是否大於等於引數2 -f — 檢查某檔案是否存在(例如,if [ -f "filename" ]) -d — 檢查目錄是否存在
幾乎所有的判斷都可以用這些比較運算子實現。指令碼中常用-f命令選項在執行某一檔案之前檢查它是否存在。
參考文章:用shell指令碼監控程序是否存在 不存在則啟動的例項
Linux下檢測程序是否存在
這個問題看起來好像很簡單,ps ef grep xx 一下就行啦!這樣做當然可以,但是如果我們考究起效能來,這恐怕不是個好辦法。假設我們現在要監測某程序是否存活,每分鐘檢查一次,用上面的辦法就要每分鐘執行一次ps命令並且做一次grep正則查詢。這點開銷在伺服器上似乎不算什麼,然而如果我們要在同一節點...
Linux下判斷是否存在多個同名程序
linux 下如何判斷同名程序的個數,這個可以通過shell命令ps e grep c 所查程序名字 就可以得到程序的個數。這裡給出 實現。bool processnumber char name char buf 255 sprintf cmd,ps e grep c s name if fptr...
Linux下C語言實現檢視程序是否存在
基本思路是先定義乙個file指標,用該指標接收popen 執行ps指令的返回值,再從指標中讀取資料到快取,根據得到的資料判斷程序是否存在,怎麼操作要看ps的引數了。示例一 下面這個示例從網上找的,根據個數來判斷程序是否存在 include include include include includ...