轉自:http://www.vip-tarena.com/PHPpeixun/478.html
公司把一些公共代碼放在include_path目錄中,作的項目只用到驗證,並且必需要修改一下,由於有些操做容許匿名,原來的只要沒登陸就會header("location:/");exit;因此該環境include_path沒有文件, 項目上線後期發現,還要引入一些其它文件,運維人員把文件都同步到include_path下了,結果crontab執行不了php了,由於本來引入項目中文件如今引入include_path下的文件(是同名,功能同樣,只不過本身項目中的作了點修改),後來在crontab中加入了
*/10 * * * * cd /var/www/cron && 。。。。。
結果濤聲依舊。話說我轉的文章,把問題寫的至關詳細。
用crontab跑php程序時,如何去調試,各人有各人的方法。我也有套方法,看一下,我是如何解決crontab執行不了
php
程序這個問題的。
一,php文件有沒有執行權限
- 1.[root@linux cron]# ls -al |grep del
- 2. -rwxr-xr-x 1 zwh ftpgroup 494 10-20 16:42 del_redis.php
複製代碼
若是沒有
X
,說明沒有執行權限,固然也執行不了。若是你不知道你登陸的用戶所在的組是否是有權限,直接給全部組都加上權限就好了。方法以下:
- [root@linux cron]# chmod +x ./del_redis.php
複製代碼
二,若是有執行權限了,仍是執行不了
解決方法以下:
1,在php程序裏面寫log(例如:error_log()這個函數),這也是必須的,由於crontab定時執行,要是沒有log,你怎麼知道程序執行的結果怎麼樣。這樣咱們能夠經過log來查看crontab執行的狀況。 php
2,也能夠直接在crontab裏面,將執行的結果輸出一個文件當中。而後在這個文件當中查看執行狀況。例如: html
- 1.*/10 * * * * /usr/local/php/bin/php /var/www/cron/del_redis.php >> /home/zhangy/cron.txt
複製代碼
3,
用crontab來執行php,是不走apache,nginx,因此$_SERVER,$_ENV這類變量根本用不了
。因此檢查一php 代碼中有沒有這類變量,若是有拿掉。
4,php的相對路徑問題 mysql
由於有思惟定勢在作怪,這個問題也是最容易忽視的。 linux
- 1.include_once'./mysql.php';
複製代碼
當php代碼中,用的是相對路徑時,只有進入到那個目錄下執行/usr/local/php/bin/php /var/www/cron/level_rank.php才能生效。
這個問題我遇到過至少二次,可是再遇到時仍是想不起來。解決方法以下:
- 1.*/10 * * * * cd /var/www/cron && /usr/local/php/bin/php /var/www/cron/level_rank.php
複製代碼
也能夠直接在php代碼中用絕對路徑