nginx解析PHP特卡,nginx解析PHP程序报错的解决方案

[root@server-2 log]# tail -f nginx/error.log

2019/07/31 01:51:02 [error] 26151#0: *52 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: 192.168.1.124, server: localhost, request: "GET /test.php HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host: "192.168.1.136"

nginx解析PHP页面时无法显示出来,查看nginx日志,报错信息如上;

查看资料

原因:

在fastcgi_params文件(和nginx.conf文件在同一个目录下)里定义了许多与fastcgi程序相关的变量,当nginx通过fastcgi接口发送请求时它要去定义好的地方去解析相应的变量值,然后交给php去处理,很显然,如果fastcgi获取不了相应的值,那么他就无法把相应请求转发给php程序,自然无法解析。

这个问题的关键在于"Primary script unknown”主脚本未知,也就是fastcgi程序无法找到定义的要执行的脚本,默认的配置文件fastcgi_params定义的变量中并没有$fastcgi_script_name这个变量,但是在fastcgi.conf里定义了。所以我们要么包含这个fastcgi.conf文件,要么把fastcgi_params里的SCRIPT_FILENAME 构建成和fastcgi.conf里的值一样,加上$document_root参数(这个参数的值就代表站点目录root那一行的值)。

解决方案1

在配置最后一行包含fastcgi.conf配置文件,结果如下

1 location ~ \.php$ {

2 root html/wordpress;

3 fastcgi_pass 127.0.0.1:9000;

4 fastcgi_index index.php;

5 fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;

6 include fastcgi_params;

7 include fastcgi.conf;

8 }

解决方案2

把fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;这一行,改为:fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

1 location ~ \.php$ {

2 root html/wordpress;

3 fastcgi_pass 127.0.0.1:9000;

4 fastcgi_index index.php;

5 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

6 include fastcgi_params;

7 }

标签:php,script,nginx,报错,conf,PHP,root,fastcgi

来源: https://blog.51cto.com/14101466/2429115

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值