解决搭建好LNMP环境之后,出现了Access Denied错误

分类:CentOS运维 阅读:18186 次

搭建好LNMP环境之后,出现了Access Denied错误,现已排除掉文件权限的问题也排除掉是Nginx的问题,而是无法解析PHP的问题。

发现网上的很多大牛都是通过Nginx的log来排查错误,但是打开nginx.conf发现其实我的log信息不够详细,于是希望能够配置一下log_format

配置Nginx的 log_format

①打开nginx.conf

②将原来的log_format那一行删掉,用下面这部分替换

log_format main '$remote_addr - $remote_user [$time_local] '

'fwf[$http_x_forwarded_for] tip[$http_true_client_ip] '

'$upstream_addr $upstream_response_time $request_time '

'$geoip_country_code '

'$http_host $request '

'"$status" $body_bytes_sent "$http_referer" '

'"$http_accept_language" "$http_user_agent" '

③保存退出

重启nginx

打开nginx的日志文件,找到error.log,tail -f error.log,发现如下错误

解决搭建好LNMP环境之后,出现了Access Denied错误

从第一行中可以发现是PHP报错,搜索问题,发现是因为php限定了php仅能运行的目录,现在只能在/tmp/文件夹下运行,所以在nginx的www-root文件夹下运行不了,所以发生了拒绝访问的错误

解决方案:

①打开php.ini文件

②找到open_basedir处

③将该行注释掉,注释掉的意思就是说php可以在任何文件夹下运行,如果希望能够在指定的文件夹下运行,则将open_basedir设定成相应的目录

④保存并退出

重启PHP-FPM service php-fpm restart

然后访问网页,发现解决了问题。