前提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...
前提
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]#
本文标题为:CentOs7Nginx+php-fpm出现访问php文件404 not found
基础教程推荐
- php array分组,PHP中array数组的分组排序 2022-08-01
- PHP获取MySQL执行sql语句的查询时间方法 2022-11-09
- PHP实现Redis单据锁以及防止并发重复写入 2022-10-12
- laravel ORM关联关系中的 with和whereHas用法 2023-03-02
- 使用PHP开发留言板功能 2023-03-13
- laravel 解决多库下的DB::transaction()事务失效问题 2023-03-08
- PHP中的错误及其处理机制 2023-06-04
- PHP命名空间简单用法示例 2022-12-01
- thinkphp3.2.3框架动态切换多数据库的方法分析 2023-03-19
- 在Laravel中实现使用AJAX动态刷新部分页面 2023-03-02