我正在尝试在一个 Red Hat 7 Amazon EC2 实例 (ami-8cff51fb) 上安装一个基于 PHP 的 软件包,此实例已使用 yum 安装了 Apache 2.4.6 和 PHP 5.4.16。但是安装失败,因为它说特定的目录需要由 Web 服务器以 0755 或 0775 权限可写。
所涉及的目录具有 0775 权限和root:apache
所有权。我已验证 httpd 进程由 apache 用户运行,并且 apache 用户是 apache 组的成员。
如果我编辑/etc/passwd
临时给予 apache 用户登录 shell,然后su
到该账户,我可以使用touch
命令手动创建文件作为 apache 用户在该目录中。
我查看了安装程序脚本的源代码并确定它失败是因为 PHP 的is_writable()
函数对所讨论的目录返回 false。我创建了一个单独的测试 PHP 脚本来隔离和验证我看到的行为:
<?php
$dir = '/var/www/html/limesurvey/tmp';
if (is_writable($dir)) {
echo $dir, ' is writable';
} else {
echo $dir, ' is NOT writable';
}
?>
这将输出“不可写”消息。如果我将上面的$dir
更改为/tmp
,则正确输出/tmp
可写。如果我将目录权限更改为0777和/或更改所有权为
apache:apache
,那么PHP仍会报告该目录不可写。我甚至尝试创建一个设置了相同权限和所有权的/test
目录,并且我的测试脚本仍将其报告为不可写。我真的无法解释这种行为,所以欢迎任何想法!
提前致谢。
以下是
/var/www/html/limesurvey
目录清单。如同Lime Survey的安装说明,tmp
和upload
目录具有0775权限。test.php
是我上面提到的测试脚本。[ec2-user@ip-xx-x-x-xxx limesurvey]$ pwd
/var/www/html/limesurvey
[ec2-user@ip-xx-x-x-xxx limesurvey]$ ls -al
total 80
drwxr-xr-x. 20 root apache 4096 Mar 30 11:25 .
drwxr-xr-x. 3 root root 23 Mar 25 14:41 ..
drwxr-xr-x. 2 root apache 38 Mar 10 12:56 admin
drwxr-xr-x. 16 root apache 4096 Mar 10 12:56 application
drwxr-xr-x. 3 root apache 4096 Mar 10 12:56 docs
drwxr-xr-x. 2 root apache 4096 Mar 10 12:56 fonts
drwxr-xr-x. 19 root apache 4096 Mar 10 12:56 framework
-rw-r--r--. 1 root apache 429 Mar 10 12:56 .gitattributes
-rw-r--r--. 1 root apache 399 Mar 10 12:56 .gitignore
-rw-r--r--. 1 root apache 296 Mar 10 12:56 .htaccess
drwxr-xr-x. 4 root apache 4096 Mar 10 12:56 images
-rw-r--r--. 1 root apache 6652 Mar 10 12:56 index.php
drwxr-xr-x. 5 root apache 39 Mar 10 12:56 installer
drwxr-xr-x. 89 root apache 4096 Mar 10 12:56 locale
drwxrwxr-x. 2 root apache 39 Mar 25 14:41 logs
drwxr-xr-x. 4 root apache 49 Mar 10 12:56 plugins
-rw-r--r--. 1 root apache 61 Mar 10 12:56 README
drwxr-xr-x. 4 root apache 4096 Mar 10 12:56 scripts
-rw-r--r--. 1 root apache 380 Mar 10 12:56 .scrutinizer.yml
drwxr-xr-x. 5 root apache 4096 Mar 10 12:56 styles
drwxr-xr-x. 5 root apache 4096 Mar 10 12:56 styles-public
drwxr-xr-x. 12 root apache 4096 Mar 10 12:56 templates
-rw-r--r--. 1 root apache 159 Mar 30 11:11 test.php
drwxr-xr-x. 3 root apache 20 Mar 10 12:56 themes
drwxr-xr-x. 26 root apache 4096 Mar 10 12:56 third_party
drwxrwxr-x. 5 root apache 80 Mar 26 13:45 tmp
drwxrwxr-x. 6 root apache 79 Mar 10 12:57 upload
运行 namei -l /var/www/html/limesurvey/tmp
命令,结果如下:
[ec2-user@ip-x-x-x-xxx ~]$ namei -l /var/www/html/limesurvey/tmp
f: /var/www/html/limesurvey/tmp
drwxr-xr-x root root /
drwxr-xr-x root root var
drwxr-xr-x root root www
drwxr-xr-x root root html
drwxr-xr-x root apache limesurvey
drwxrwxr-x root apache tmp
touch
时会发生什么? - exussumecho exec('id', $output)
返回uid=48(apache) gid=48(apache) groups=48(apache) context=system_u:system_r:httpd_t:s0
- 查看/etc/group
,它有apache:x:48:apache
。 - John Topleytouch
函数在目录中创建文件时,它返回了false。 - John Topley