CakePHP权限错误

约书亚·沃尔什(Joshua Walsh):

这似乎是重复的,但是我已经阅读了类似的问题,并尝试了他们的建议,但没有成功。

导航到CakePHP网站时,出现以下错误

警告(2):mkdir():权限被拒绝[CORE / src / Cache / Engine / FileEngine.php,第417行]

警告:file_put_contents(/var/www/html/my-application/logs/error.log)[function.file-put-contents]:无法打开流:/ var / www / html / my-application /中的权限被拒绝第134行的vendor / cakephp / cakephp / src / Log / Engine / FileLog.php

警告(512):/ var / www / html / my-application / tmp / cache / persistent /无法写入[CORE / src / Cache / Engine / FileEngine.php,第425行]

警告(2):file_put_contents(/var/www/html/my-application/logs/error.log)[function.file-put-contents]:无法打开流:权限被拒绝[CORE / src / Log / Engine / FileLog.php,第134行]

警告:file_put_contents(/var/www/html/my-application/logs/error.log)[function.file-put-contents]:无法打开流:/ var / www / html / my-application /中的权限被拒绝第134行的vendor / cakephp / cakephp / src / Log / Engine / FileLog.php

问题是我确定PHP可以访问所有必需的文件。

PHP在组apache中以用户apache的身份运行。证据:

[ec2-user@cv-stg01 my-application]$ ps -efl | grep apache
5 S apache   21863 21861  0  80   0 - 124037 SYSC_s 03:06 ?       00:00:00 /usr/sbin/httpd -DFOREGROUND
5 S apache   21864 21861  0  80   0 - 123971 SYSC_s 03:06 ?       00:00:00 /usr/sbin/httpd -DFOREGROUND
5 S apache   21865 21861  0  80   0 - 123485 SYSC_s 03:06 ?       00:00:00 /usr/sbin/httpd -DFOREGROUND
5 S apache   21867 21861  0  80   0 - 124037 SYSC_s 03:06 ?       00:00:00 /usr/sbin/httpd -DFOREGROUND
5 S apache   21868 21861  0  80   0 - 123485 SYSC_s 03:06 ?       00:00:00 /usr/sbin/httpd -DFOREGROUND
5 S apache   21869 21861  0  80   0 - 123485 SYSC_s 03:06 ?       00:00:00 /usr/sbin/httpd -DFOREGROUND
5 S apache   21870 21861  0  80   0 - 124037 SYSC_s 03:06 ?       00:00:00 /usr/sbin/httpd -DFOREGROUND
5 S apache   21881 21861  0  80   0 - 123485 SYSC_s 03:09 ?       00:00:00 /usr/sbin/httpd -DFOREGROUND
5 S apache   21882 21861  0  80   0 - 123485 SYSC_s 03:09 ?       00:00:00 /usr/sbin/httpd -DFOREGROUND
5 S apache   21883 21861  0  80   0 - 125444 ep_pol 03:09 ?       00:00:00 /usr/sbin/httpd -DFOREGROUND
0 S ec2-user 21934 21785  0  80   0 - 28161 pipe_w 03:20 pts/0    00:00:00 grep --color=auto apache

相关目录归apache:apache所有,并且权限设置为777:

[ec2-user@cv-stg01 my-application]$ ls -l
total 132
drwxrwxr-x.  2 apache apache    47 May 12 21:16 bin
-rw-rw-r--.  1 apache apache  1128 May 12 21:16 composer.json
-rw-rw-r--.  1 apache apache 93002 May 12 21:16 composer.lock
drwxrwxr-x.  3 apache apache  4096 May 12 21:19 config
-rw-rw-r--.  1 apache apache   648 May 12 21:16 index.php
drwxrwxrwx.  2 apache apache    34 May 13 03:10 logs
-rw-rw-r--.  1 apache apache  1139 May 12 21:16 phpunit.xml.dist
drwxrwxr-x.  2 apache apache    18 May 12 21:16 plugins
-rw-rw-r--.  1 apache apache   980 May 12 21:16 README.md
drwxrwxr-x.  9 apache apache  4096 May 12 21:16 src
drwxrwxrwx.  4 apache apache    55 May 12 21:16 tests
drwxrwxrwx.  2 apache apache     6 May 13 03:17 tmp
drwxrwxr-x. 28 apache apache  4096 May 12 21:16 vendor
drwxrwxr-x.  9 apache apache  4096 May 12 21:16 webroot

tmp /中的子目录也具有正确的权限:

[ec2-user@cv-stg01 tmp]$ ls -l
total 0
drwxrwxrwx. 5 apache apache 48 May 12 21:16 cache
drwxrwxrwx. 2 apache apache 18 May 12 21:16 sessions
drwxrwxrwx. 2 apache apache 18 May 12 21:16 tests

我也尝试过重新申请权限,以防万一,

sudo chown -R apache:apache /var/www/html/my-application
sudo chmod -R 777 /var/www/html/my-application/tmp
sudo chmod -R 777 /var/www/html/my-application/logs
sudo chmod -R 777 /var/www/html/my-application/tests

我什至以apache身份登录并亲自编辑了文件,没有任何问题

sudo su -s /bin/bash apache
vi /var/www/html/my-applciation/logs/error.log

我真的很想找出现在可能出现的问题。

我们已经安装/启用了SELinux,也许这引起了问题?

帮助将不胜感激。

谢谢,

其他

约书亚·沃尔什(Joshua Walsh):

问题是SELinux。使用以下命令已解决该问题:

chcon -R system_u:object_r:var_lib_t:s0 tmp
chcon -R  system_u:object_r:var_lib_t:s0 logs
chcon system_u:object_r:httpd_var_lib_t:s0 logs/*
chcon system_u:object_r:httpd_var_lib_t:s0 tmp/debug_kit.sqlite
chcon  system_u:object_r:var_lib_t:s0 tests

chmod -R o-w tmp logs tests 

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章