问题:任务www用户不能执行,root用户可以执行,但是直接执行命令是可以的,下面是我的执行步骤

1、在/etc/crontab下写入命令

SHELL=/bin/bash

PATH=/sbin:/bin:/usr/sbin:/usr/bin

MAILTO=root

# For details see man 4 crontabs

# Example of job definition:

# .---------------- minute (0 - 59)

# | .------------- hour (0 - 23)

# | | .---------- day of month (1 - 31)

# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...

# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat

# | | | | |

# * * * * * user-name command to be executed

* * * * * www php /www/wwwroot/market/api/think sync:account:token >> /dev/null 2>&1

2、查看cron日志

tail -f /var/log/cron

查看结果如下,并没有报错,但是我的程序并没得到成功执行

Jun 10 16:47:01 localhost CROND[151514]: (www) CMD (php /www/wwwroot/market/api/think sync:account:token >> /dev/null 2>&1)

3、找错误

3.1尝试把第一步中的www用户改为root,一分钟后程序得到成功执行

3.2、尝试直接命令

sudo -u www php /www/wwwroot/market/api/think sync:account:token

程序得到成功执行

3.3 /etc下只有cron.deny文件,并没有cron.allow文件,而且cron.deny文件为空

3.4 文件的权限如下

3.4.1 php的执行权限

lrwxrwxrwx 1 root root 26 12月 11 09:46 /usr/bin/php -> /www/server/php/72/bin/php

3.4.6 /www/wwwroot/market/api/think

-rwxr-xr-x 1 www www 180 5月 30 16:33 think

直接执行是可以成功,所以文件权限已经确保是足够的!

Logo

更多推荐