写日志的方法中用到 file_put_contents 这个方法,今天在执行回调方法的写日志的时候提示没有写入文件权限,报错提示php
file_put_contents: failed to open stream: Permission denied
检查日志文件夹权限,由于是按天生成的,有个定时任务定时执行,执行用户是root,因此生成文件夹用户和用户组都是root,而回调方法中执行用户是www,写入日志方法中linux
if(!is_dir($dir)){ mkdir($dir,0777,true); }
若是目录不存在,建立目录,可是在php的mkdir函数建立文件夹设置777权限,实际上建立的文件仍是755的权限。 在linux系统中在建立文件/文件夹时有一个默认权限,此权限受 umask 设置影响,在/etc/bashrc配置文件中咱们能够找到以下配置:bash
if [ $UID -gt 99 ] && [ "`id -gn`" = "`id -un`" ]; then umask 002 else umask 022 fi
linux系统中默认的umask为022,与咱们的777 &运算以后,就变成了 755,这就是缘由所在了。 这里的设置直接影响到linux系统的默认权限设置,不单单是PHP的问题。因此不建议直接进行修改把022 改成 000 。函数
先建立目录,再使用chmod将权限修改成 777日志
mkdir('test', 0777); chmod('test', 0777);