nginx 踩坑之 403 Forbidden

        有一部分人在源码安装nginx的时候考虑到安全原因,在Linux服务器上安装nginx的时候会创建一个普通用户nginx用户,防止别人通过攻击web服务器后获取到服务器的root权限,通过root来修改服务器的其他一些参数信息,登陆服务器的权限为/sbin/nologin,等安装完后利用浏览器或者服务器curl访问,发现报403 Forbidden  ,去看error.log日志提示没有没有权限

        这个是权限配置不正确导致nginx出现403 forbidden最常见的错误。

       1、为了保证文件能正确执行,nginx既需要文件的读权限,又需要文件所有父目录的可执行权限。

我一般安装nginx的时候一般喜欢安装在/usr/local/nginx(这个目录可以自定义设置,源码安装时在./configure 后添加“--prefix=你的安装路径”),当你要访问  html/image.jpg      nginx既需要image.jpg文件的可读权限,也需要/, /usr,/usr/local,/usr/local/nginx,/usr/local/nginx/html的可以执行权限。

解决办法:设置所有父目录为755权限,设置文件为644权限可以避免权限不正确。

    2、如果发现读取和执行都是可以的,则需要检查是文件的所有者是否时你创建的普通用户 

 一般你源码安装完后文件的所有者个所属组是你当前安装的用户,导致nginx用户无法访问和读取文件的内容

解决办法:修改所有父目录及文件的所属组和所有者,

chown -R  nginx.nginx  ./usr/local/nginx/

你可能感兴趣的:(nginx)