摘要:本文分析了crontab無法執(zhí)行php的解決方法。分享給大家供大家參考,具體如下:用crontab跑php程序時,如何去調(diào)試,各人有各人的方法。我也有套方法,看一下,我是如何解決crontab執(zhí)行不了php程序這個問題的。一、php文件有沒有執(zhí)行權(quán)限[root@linux cron]# ls -al |grep del -rwxr-xr-
本文分析了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)限,當然也執(zhí)行不了。如果你不知道你登錄的用戶所在的組是不是有權(quán)限,直接給所有組都加上權(quán)限就行了。方法如下:
[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é)果輸出一個文件當中。然后在這個文件當中查看執(zhí)行情況。例如:
*/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的相對路徑問題
因為有思維定勢在做怪,這個問題也是最容易忽視的。
include_once'./mysql.php'
當php代碼中,用的是相對路徑時,只有進入到那個目錄下執(zhí)行/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代碼中用絕對路徑
更多關(guān)于crontab無法執(zhí)行php的解決方法請關(guān)注PHP中文網(wǎng)(ipnx.cn)其他文章!