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 you
10次,下面是成功后的访问:
[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]#