CentOs7Nginx+php-fpm出现访问php文件404 not found

  

前提

1.nginx成功安装并跑起来了
2.php安装成功且php-fpm成功运行
3.netstat -antp | grep :80 and netstat -antp | grep :9000 ,80和9000端口处于监听状态

问题

[root@xxx ~] # curl -i http://localhost/test.php
HTTP/1.1 404 Not Found
Server: nginx/1.14.0
Date: Fri, 19 Oct 2018 06:38:47 GMT
Content-Type: text/html; charset=UTF-8
Transfer-Encoding: chunked
Connection: keep-alive
X-Powered-By: PHP/5.6.38

File not found.

通过HTTP的响应头信息,可以看到nginx和php环境是正常的,只是文件未找到。当然我们排除那种文件路径写错的低级情况,这个自行检查。除了文件路径写错以外,最有可能的问题,就是nginx.conf文件配置错误了

我们到nginx/logs/error.log中看看日志文件,如下:

2018/10/19 14:38:47 [error] 26905#0: *5 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: 127.0.0.1, server: localhost, request: "GET /test.php HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host: "localhost"

看log我们知道,log说FastCGI[这就是php-fpm]在读响应头的输出流中找不到primary script了,这个问题比较蛇皮了,具体primary script 脚本到底是那个脚本我不知道,但是可以确定是我们的nginx配置写的有问题了,去看看nginx.conf中关于php的配置

location ~ \.php$ {
            root           html;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
            include        fastcgi_params;
        }

默认情况下,nginx对于php的配置就是如上,其中/scripts有点奇怪,这里是配置一个路径,/scriptsg更像是一个绝对路径的写法,但是ls查看一下根目录发现并没有这么一个文件,所以primary scripts找不到罪魁祸首就是他,把/scripts改为$document_root,然后重启nginx就可以了。
这里我写了一个test.php,循环输出I love you10次,下面是成功后的访问:

[root@epaper nginx]# curl http://localhost/test.php
0I love you1I love you2I love you3I love you4I love you5I love you6I love you7I love you8I love you9I love you[root@epaper nginx]# 
相关文章