- 論壇徽章:
- 0
|
crontab執(zhí)行不了php的解決方法
用crontab跑php程序時,如何去調(diào)試,各人有各人的方法。我也有套方法,看一下,我是如何解決crontab執(zhí)行不了php程序這個問題的。
一,php文件有沒有執(zhí)行權(quán)限
[root@linux cron]# ls -al |grep del
-rwxr-xr-x 1 zwh ftpgroup 494 10-20 16:42 del_redis.php
如果沒有X,說明沒有執(zhí)行權(quán)限,當(dāng)然也執(zhí)行不了。如果你不知道你登錄的用戶所在的組是不是有權(quán)限,直接給所有組都加上權(quán)限就行了。方法如下:
查看復(fù)制打印?
[root@linux cron]# chmod +x ./del_redis.php
二,如果有執(zhí)行權(quán)限了,還是執(zhí)行不了
解決方法如下:
1,在php程序里面寫log(例如:error_log()這個函數(shù)),這也是必須的,因為crontab定時執(zhí)行,要是沒有l(wèi)og,你怎么知道程序執(zhí)行的結(jié)果怎么樣。這樣我們可以通過log來查看crontab執(zhí)行的情況。
2,也可以直接在crontab里面,將執(zhí)行的結(jié)果輸出一個文件當(dāng)中。然后在這個文件當(dāng)中查看執(zhí)行情況。例如:
查看復(fù)制打印?
*/10 * * * * /usr/local/php/bin/php /var/www/cron/del_redis.php >> /home/zhangy/cron.txt
3,用crontab來執(zhí)行php,是不走apache,nginx,所以$_SERVER,$_ENV這類變量根本用不了。所以檢查一下php代碼中有沒有這類變量,如果有拿掉。
4,php的相對路徑問題
因為有思維定勢在做怪,這個問題也是最容易忽視的。
查看復(fù)制打印?
include_once'./mysql.php';
當(dāng)php代碼中,用的是相對路徑時,只有進(jìn)入到那個目錄下執(zhí)行/usr/local/php/bin/php /var/www/cron/level_rank.php才能生效。這個問題我遇到過至少二次,但是再遇到時還是想不起來。
解決方法如下:
查看復(fù)制打印?
*/10 * * * * cd /var/www/cron && /usr/local/php/bin/php /var/www/cron/level_rank.php
或者
在php代碼中用絕對路徑
詳細(xì)見
http://blog.51yip.com/php/1346.html
|
|