91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

crontab定時任務不執行的一些原因總結

發布時間:2020-09-07 00:58:54 來源:腳本之家 閱讀:314 作者:田野上的希望 欄目:服務器

前言

最近在工作中遇到了一些問題,crontab定時任務居然不執行,后來我在網上找的時候發現網上主要說了這5個原因:

1 crond服務未啟動

crontab不是Linux內核的功能,而是依賴一個crond服務,這個服務可以啟動當然也可以停止。如果停止了就無法執行任何定時任務了,解決的方法是打開它:

crond

service crond start

如果提示crond命令不存在,可能被誤刪除了,CentOS下可以通過這個命令重新安裝:

yum -y install crontabs

2 權限問題

比如:腳本沒有x執行權限,解決方法:

增加執行權限,或者用bash abc.sh的方法執行

也有可能crontab任務所屬的用戶對某個目錄沒有寫權限,也會失敗

3 路徑問題

有的命令在shell中執行正常,但是在crontab執行卻總是失敗。有可能是因為crontab使用的sh未正確識別路徑,比如:以root身份登錄shell后執行一個/root/test.sh,只要執行

./test.sh

就可以了。但是在crontab中,就會找不到這個腳本,比如寫完整:

/root/test.sh

4 時差問題

因為服務器與客戶端時差問題,所以crontab的時間以服務器時間為準。

時差這個問題還真是搞人,這個我親身體驗了,現象如下:

(1) 我設置了一個定時腳本,用date命令觀察服務器的時間到了腳本執行的時間點,發現沒有執行

(2) 但是我把腳本設置成每分鐘執行一次,就是OK的

見鬼了,服務器時間是對的啊?莫非是要加個什么時區?于是把腳本的時間減10或者12或者8個小時都嘗試了下,發現都不行。

但是很明顯是時間不一致導致的不執行。

最后用如下兩行解決了問題:

cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
service crond restart

參考這篇文章: https://www.jb51.net/article/154296.htm

5 變量問題

有時候命令中含有變量,但crontab執行時卻沒有,也會造成執行失敗。

驗證后,我的定時腳本test.sh不執行不是上述任何一種原因,其實我的腳本就一句話:

#!/bin/bash
echo 123 >> testFile

我希望通過這種方式來測試 我設置的定時腳本起作用了,于是我設置了該腳本每分鐘執行一次,但是死活在腳本所在目錄看不到這個文件,我手動執行

# sh test.sh

卻能看到在腳本所在目錄能看到這個文件

我懷疑是crontab根本沒有執行,于是我在crontab中直接添加了

*/1 * * * * echo 123 >> /home/denglinjie/testFile

testFile文件生成了,說明crontab是執行了的,那看來是我腳本自身存在問題

最后發現,原來是testFile這里必須寫完整的路徑,我天真的以為testFile會生成在腳本所在的目錄,所以改成了如下形式

#!/bin/bash
echo 123 >> /data/denglinjie/testFile

然后就可以了。

其實路徑是個非常容易出問題的地方,假設在/home/denglinjie目錄下有一個腳本文件test1.sh,然后在該目錄下還有一個腳本文件test2.sh

在test1.sh中執行了test2.sh,而且用的是相對路徑,即相對test1.sh所在的路徑。

如果在crontab -e中編輯的時候,執行的方式是

sh /home/denglinjie/test1.sh,當執行到調用sh test2.sh的時候,系統會認為是從crontab文件所在的目錄去找test2.sh,但是其實是找不到的,造成執行失敗

最開始我想的方法是,我要將我寫的待執行的腳本文件以及被調用的其他的腳本和crontab文件放到一個地方,這樣就可以拉,但是失敗了,可能是因為權限問題,我進不去/var/spool/cron目錄。

所以另外一個解決方法就是在執行腳本之前先通過 cd   /home/denglinjie 命令進入到腳本所在目錄

------------------------------------------------------------------

最近又發現一種新的引起crontab不執行的原因

這里我要執行的是python腳本,我python腳本的目錄為:

/data/denglinjie/work/UpdateModuleSwitch

一開始我的定時任務是這樣寫的:

0 * * * * cd /data/denglinjie/work/UpdateModuleSwitch;python update_switch.py

發現到了時間點居然沒有執行,其中update_switch.py的部分內容如下:

import pymongo

就是我的腳本中引入了自己安裝的pymongo, 注意,這個pymongo是安裝到了指定的python版本上的

不執行原因:crontab定時任務執行的時候,使用的python不是我的那個python,使用的這個python沒有安裝pymongo,導致import失敗

解決辦法,改成如下形式:

0 * * * * cd /data/denglinjie/work/UpdateModuleSwitch;/data/zhoumi/install_evn/bin/python update_switch.py

指定運行使用的python,這個python已經安裝綁定了pymongo,或者用如下形式:

0 * * * * export PATH=/data/zhoumi/install_evn/bin/:$PATH;cd /data/denglinjie/work/UpdateModuleSwitch;python update_switch.py

因為我的這個python是安裝在我自己的用戶目錄下,所以系統找不到這個python,所以只要將我的python也加入到系統PATH環境變量中就可以了

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

呼和浩特市| 顺昌县| 娱乐| 鸡西市| 宁都县| 醴陵市| 桑植县| 盘锦市| 新河县| 周至县| 深圳市| 昌图县| 合山市| 伊春市| 龙山县| 邯郸县| 遂溪县| 榆中县| 林州市| 清镇市| 大荔县| 房山区| 上虞市| 隆回县| 清丰县| 绵竹市| 秦安县| 大竹县| 潮安县| 潍坊市| 南充市| 淅川县| 富阳市| 珲春市| 四子王旗| 邵武市| 卓资县| 河津市| 民乐县| 临高县| 张家港市|