我是在在本地用虛擬機中通過yum安裝nginx的,安裝一切正常,但是訪問時報403,
於是查看nginx日誌,路徑爲/var/log/nginx/error.log。打開日誌發現報錯Permission denied,詳細報錯如下:
1. open() "/data/www/1.txt" failed (13: Permission denied), client: 192.168.1.194, server: www.web1.com, request: "GET /1.txt HTTP/1.1", host: "www.web1.com"
沒有權限?於是找了不少資料,可以通過下面四步排查解決此問題。你可能只是其中之前配置有問題,不一定四個步驟都用上。
一、由於啓動用戶和nginx工作用戶不一致所致
1.1查看nginx的啓動用戶,發現是nobody,而爲是用root啓動的
命令:ps aux | grep "nginx: worker process" | awk'{print $1}'
1.2將nginx.config的user改爲和啓動用戶一致,
命令:vi conf/nginx.conf
二、缺少index.html或者index.php文件,就是配置文件中index index.html index.htm這行中的指定的文件。
1. server {
2. listen 80;
3. server_name localhost;
4. index index.php index.html;
5. root /data/www/;
6. }
如果在/data/www/下面沒有index.php,index.html的時候,直接文件,會報403 forbidden。
三、權限問題,如果nginx沒有web目錄的操作權限,也會出現403錯誤。
解決辦法:修改web目錄的讀寫權限,或者是把nginx的啓動用戶改成目錄的所屬用戶,重啓Nginx即可解決
1. chmod -R 777 /data
2. chmod -R 777 /data/www/
四、SELinux設置爲開啓狀態(enabled)的原因。
4.1、查看當前selinux的狀態。
1. /usr/sbin/sestatus
4.2、將SELINUX=enforcing 修改爲 SELINUX=disabled 狀態。
1. vi /etc/selinux/config
2. #SELINUX=enforcing
3. SELINUX=disabled
4.3、重啓生效。reboot。