解決Nginx出現403 forbidden (13: Permission denied)報錯的四種方法


之前對於nginx不甚了解,所以一知半解,再次把遇到的問題,總結下

1.之前服務器是root權限傳過去的前端文件,重啟一直是NGINX的重啟命令 ./sbin/nginx。后來就重啟不了了,找了錯誤日志,打開日志發現報錯權限錯誤,詳細報錯如下

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.     

3.    #SELINUX=enforcing

4.    SELINUX=disabled

4.3、重啟生效。reboot。

1.    reboot

(本來想自己寫,后來發現了up主寫的更詳細,故放此https://www.cnblogs.com/williamjie/p/9604594.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM