Nginx+PHP配置错误,日志:[error] 24324#0: *31 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream
2024-08-28 20:22:04
一、问题现象
1、安装nginx、php、php-fpm后,浏览器访问php报错,“File not found”;
二、问题排查
1、检查nginx、php-fpm服务是否正常启动,均正常启动;
2、检查服务端口号,分别是nginx:81、php:9000
3、查看nginx错误日志 /usr/local/nginx/logs/error.log tail -n 20 error.log
[error] 24324#0: *31 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream
三、解决方法
1、粘贴错误日志信息到百度,发现是nginx配置文件缺少参数导致,参考链接:https://www.cnblogs.com/php-linux/p/6526641.html
首先简单的讲一讲原理,目前主流的nginx+php的运行原理如下:
1> nginx的worker进程直接管理每一个请求到nginx的网络请求。
2> 对于php而言,由于在整个网络请求的过程中php是一个cgi程序的角色,所以采用名为php-fpm的进程管理程序来对这些被请求的php程序进行管理。php-fpm程序也如同nginx一样,需要监听端口,并且有master和worker进程。worker进程直接管理每一个php进程。
3> 关于fastcgi:fastcgi是一种进程管理器,管理cgi进程。市面上有多种实现了fastcgi功能的进程管理器,php-fpm就是其中的一种。再提一点,php-fpm作为一种fast-cgi进程管理服务,会监听端口,一般默认监听9000端口,并且是监听本机,也就是只接收来自本机的端口请求,所以我们通常输入命令 netstat -nlpt|grep php-fpm 会得到:
tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 1057/php-fpm
这里的127.0.0.1:9000 就是监听本机9000端口的意思。
4> 关于fastcgi的配置文件,目前fastcgi的配置文件一般放在nginx.conf同级目录下,配置文件形式,一般有两种:fastcgi.conf 和 fastcgi_params。不同的nginx版本会有不同的配置文件,这两个配置文件有一个非常重要的区别:fastcgi_parames文件中缺少下列配置:
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
我们可以打开fastcgi_parames文件加上上述行,也可以在要使用配置的地方动态添加。使得该配置生效。
5> 当需要处理php请求时,nginx的worker进程会将请求移交给php-fpm的worker进程进行处理,也就是最开头所说的nginx调用了php,其实严格得讲是nginx间接调用php。
2、修改nginx.conf配置文件,添加 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; 到文件中;
1> 第一个大括号 server{ }:不必多说,代表一个独立的server,
2> listen 8011:代表该server监听8011端口
3> location ~ \.php?.*${ }:代表一个能匹配对应uri的location,用于匹配一类uri,并对所匹配的uri请求做自定义的逻辑、配置。这里的location,匹配了所有带.php的uri请求,例如:http://192.168.244.128:8011/test.php/asdasd http://192.168.244.128:8011/index.php等
4> root /share/test:请求资源根目录,告诉匹配到该location下的uri到/share/test文件夹下去寻找同名资源。
5> fastcgi_pass 127.0.0.1:9000:这行开始是本文的重点:这行代码的意思是,将进入到该location内的uri请求看做是cgi程序,并将请求发送到9000端口,交由php-fpm处理。
6> fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; :这行配置意思是:动态添加了一行fastcgi配置,配置内容为SCRIPT_FILENAME,告知管理进程,cgi脚本名称。由于我的nginx中只有fastcgi_params文件,没有fastcgi.conf文件,所以要使php-fpm知道SCRIPT_FILENAME的具体值,就必须要动态的添加这行配置。
7> include fastcgi_params; 引入fastcgi配置文件
以上就是最简洁版的nginx启动php脚本的最简配置,当重启nginx之后,在/share/test目录下创建一个xx.php文件,输入<?php echo "hello world"; ?>保存,然后在浏览器中访问localhost:8011/xx.php 就可以在网页上显示hello world了。
四、问题验证
1、修改nginx配置文件nginx.conf;
2、重启nginx服务,浏览器访问php文件,成功。
最新文章
- spark 大数据 LR测试
- HDOJ 题目2474 String painter(区间DP)
- qt (5.60/5.70) 编译 QOCI 驱动
- node基础03:使用函数
- C#把数据写到硬盘指定位置
- 移动互联网实战--Web Restful API设计和基础架构
- Oracle存储过程格式
- Nagios在Ubuntu server上的安装配置
- HDU 4548 美素数
- 【HDOJ】2830 Matrix Swapping II
- malloc实现原理
- Guava常用方法
- pytorch_SRU(Simple Recurrent Unit)
- docker的安装和基础使用
- IO通信模型(二)同步非阻塞模式NIO(NonBlocking IO)
- Linux chmod命令用法
- React-Native:解决真机调试时候Could not get BatchedBridge, make sure your bundle is packaged properly
- ECharts折线图多个折线每次只显示一条
- IP地址在mysql的存储(IP地址和int的转换)
- CentOS 7 开机延迟解决办法
热门文章
- 祘头君的字符(DFS)
- Angular(三)
- 笔记本安装SSD固态硬盘详细的优化设置
- vue slot插槽v-show不控制显示隐藏
- ios 获取app版本号
- Review For Exam
- Linux基础篇八:VIM
- 修改mysql密码报错: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near &#39;
- CentOS7部署yum环境及虚拟机快照克隆
- 金山wps的面试经历