今天发现线上服务器跑的脚本总是无法写记录日志,最终查到是用户权限的问题。记录日志的目录是www:www,但是我用的steven用户在执行脚本,因此,出现了这个情况。
为了避免该问题再次发,需要指定www用户来执行脚本。于是改了一下执行脚本,如下:
系统:centos 6.5
原脚本内容:
cat server_task_counts.sh
#!/bin/bash
nohup /usr/local/php/bin/php server_task_counts.php &
修改之后
cat server_task_counts.sh
#!/bin/bash
su - www <<EOF
nohup /usr/local/php/bin/php server_task_counts.php &
exit;
EOF
su - www <<EOF
nohup /usr/local/php/bin/php server_task_counts.php &
exit;
EOF
当然也可以用下面的命令来执行
代码如下:
su - test -c "pwd"
ps:
切换用户只执行一条命令的可以用: su - www -c command
切换用户执行一个shell文件可以用:su - www -s /bin/bash shell.sh
好了,就这样吧.