您好,登錄后才能下訂單哦!
前言
最近在工作中遇到了一些問題,crontab定時任務(wù)居然不執(zhí)行,后來我在網(wǎng)上找的時候發(fā)現(xiàn)網(wǎng)上主要說了這5個原因:
1 crond服務(wù)未啟動
crontab不是Linux內(nèi)核的功能,而是依賴一個crond服務(wù),這個服務(wù)可以啟動當然也可以停止。如果停止了就無法執(zhí)行任何定時任務(wù)了,解決的方法是打開它:
crond
或
service crond start
如果提示crond命令不存在,可能被誤刪除了,CentOS下可以通過這個命令重新安裝:
yum -y install crontabs
2 權(quán)限問題
比如:腳本沒有x執(zhí)行權(quán)限,解決方法:
增加執(zhí)行權(quán)限,或者用bash abc.sh的方法執(zhí)行
也有可能crontab任務(wù)所屬的用戶對某個目錄沒有寫權(quán)限,也會失敗
3 路徑問題
有的命令在shell中執(zhí)行正常,但是在crontab執(zhí)行卻總是失敗。有可能是因為crontab使用的sh未正確識別路徑,比如:以root身份登錄shell后執(zhí)行一個/root/test.sh,只要執(zhí)行
./test.sh
就可以了。但是在crontab中,就會找不到這個腳本,比如寫完整:
/root/test.sh
4 時差問題
因為服務(wù)器與客戶端時差問題,所以crontab的時間以服務(wù)器時間為準。
時差這個問題還真是搞人,這個我親身體驗了,現(xiàn)象如下:
(1) 我設(shè)置了一個定時腳本,用date命令觀察服務(wù)器的時間到了腳本執(zhí)行的時間點,發(fā)現(xiàn)沒有執(zhí)行
(2) 但是我把腳本設(shè)置成每分鐘執(zhí)行一次,就是OK的
見鬼了,服務(wù)器時間是對的???莫非是要加個什么時區(qū)?于是把腳本的時間減10或者12或者8個小時都嘗試了下,發(fā)現(xiàn)都不行。
但是很明顯是時間不一致導致的不執(zhí)行。
最后用如下兩行解決了問題:
cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime service crond restart
參考這篇文章: https://www.jb51.net/article/154296.htm
5 變量問題
有時候命令中含有變量,但crontab執(zhí)行時卻沒有,也會造成執(zhí)行失敗。
驗證后,我的定時腳本test.sh不執(zhí)行不是上述任何一種原因,其實我的腳本就一句話:
#!/bin/bash echo 123 >> testFile
我希望通過這種方式來測試 我設(shè)置的定時腳本起作用了,于是我設(shè)置了該腳本每分鐘執(zhí)行一次,但是死活在腳本所在目錄看不到這個文件,我手動執(zhí)行
# sh test.sh
卻能看到在腳本所在目錄能看到這個文件
我懷疑是crontab根本沒有執(zhí)行,于是我在crontab中直接添加了
*/1 * * * * echo 123 >> /home/denglinjie/testFile
testFile文件生成了,說明crontab是執(zhí)行了的,那看來是我腳本自身存在問題
最后發(fā)現(xiàn),原來是testFile這里必須寫完整的路徑,我天真的以為testFile會生成在腳本所在的目錄,所以改成了如下形式
#!/bin/bash echo 123 >> /data/denglinjie/testFile
然后就可以了。
其實路徑是個非常容易出問題的地方,假設(shè)在/home/denglinjie目錄下有一個腳本文件test1.sh,然后在該目錄下還有一個腳本文件test2.sh
在test1.sh中執(zhí)行了test2.sh,而且用的是相對路徑,即相對test1.sh所在的路徑。
如果在crontab -e中編輯的時候,執(zhí)行的方式是
sh /home/denglinjie/test1.sh,當執(zhí)行到調(diào)用sh test2.sh的時候,系統(tǒng)會認為是從crontab文件所在的目錄去找test2.sh,但是其實是找不到的,造成執(zhí)行失敗
最開始我想的方法是,我要將我寫的待執(zhí)行的腳本文件以及被調(diào)用的其他的腳本和crontab文件放到一個地方,這樣就可以拉,但是失敗了,可能是因為權(quán)限問題,我進不去/var/spool/cron目錄。
所以另外一個解決方法就是在執(zhí)行腳本之前先通過 cd /home/denglinjie 命令進入到腳本所在目錄
------------------------------------------------------------------
最近又發(fā)現(xiàn)一種新的引起crontab不執(zhí)行的原因
這里我要執(zhí)行的是python腳本,我python腳本的目錄為:
/data/denglinjie/work/UpdateModuleSwitch
一開始我的定時任務(wù)是這樣寫的:
0 * * * * cd /data/denglinjie/work/UpdateModuleSwitch;python update_switch.py
發(fā)現(xiàn)到了時間點居然沒有執(zhí)行,其中update_switch.py的部分內(nèi)容如下:
import pymongo
就是我的腳本中引入了自己安裝的pymongo, 注意,這個pymongo是安裝到了指定的python版本上的
不執(zhí)行原因:crontab定時任務(wù)執(zhí)行的時候,使用的python不是我的那個python,使用的這個python沒有安裝pymongo,導致import失敗
解決辦法,改成如下形式:
0 * * * * cd /data/denglinjie/work/UpdateModuleSwitch;/data/zhoumi/install_evn/bin/python update_switch.py
指定運行使用的python,這個python已經(jīng)安裝綁定了pymongo,或者用如下形式:
0 * * * * export PATH=/data/zhoumi/install_evn/bin/:$PATH;cd /data/denglinjie/work/UpdateModuleSwitch;python update_switch.py
因為我的這個python是安裝在我自己的用戶目錄下,所以系統(tǒng)找不到這個python,所以只要將我的python也加入到系統(tǒng)PATH環(huán)境變量中就可以了
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。