用crontab跑php程序時,如何去調試,各人有各人的方法。我也有套方法,看一下,我是如何解決crontab執行不了php程序這個問題的。
php
一,php文件有沒有執行權限mysql
[root@linux cron]# ls -al |grep del -rwxr-xr-x 1 zwh ftpgroup 494 10-20 16:42 del_redis.php
若是沒有X,說明沒有執行權限,固然也執行不了。若是你不知道你登陸的用戶所在的組是否是有權限,直接給全部組都加上權限就好了。方法以下:linux
查看複製打印?nginx
[root@linux cron]# chmod +x ./del_redis.php
二,若是有執行權限了,仍是執行不了redis
解決方法以下:sql
1,在php程序裏面寫log(例如:error_log()這個函數),這也是必須的,由於crontab定時執行,要是沒有log,你怎麼知道程序執行的結果怎麼樣。這樣咱們能夠經過log來查看crontab執行的狀況。apache
2,也能夠直接在crontab裏面,將執行的結果輸出一個文件當中。而後在這個文件當中查看執行狀況。例如:函數
查看複製打印?調試
*/10 * * * * /usr/local/php/bin/php /var/www/cron/del_redis.php >> /home/zhangy/cron.txt
3,用crontab來執行php,是不走apache,nginx,因此$_SERVER,$_ENV這類變量根本用不了。因此檢查一下php代碼中有沒有這類變量,若是有拿掉。code
4,php的相對路徑問題
由於有思惟定勢在作怪,這個問題也是最容易忽視的。
查看複製打印?
include_once'./mysql.php';
當php代碼中,用的是相對路徑時,只有進入到那個目錄下執行/usr/local/php/bin/php /var/www/cron/level_rank.php才能生效。這個問題我遇到過至少二次,可是再遇到時仍是想不起來。
解決方法以下:
查看複製打印?
*/10 * * * * cd /var/www/cron && /usr/local/php/bin/php /var/www/cron/level_rank.php
或者
在php代碼中用絕對路徑