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 }
- 点赞
- 收藏
- 分享
- 文章举报
- Centos6.5 通过yum安装nginx及配置
- 反向-代理 nginx for Mac 的配置以及使用
- nginx1.16编译安装config参数
- 阿里云 ubuntu nginx 发布 rails 项目
- linux下通过nginx部署前后分离的微服务项目
- nginx做域名转发和uri转发
- 【Nginx】最新版nginx安装
- nginx reload 命令报:nginx: [erro 4000 r] invalid PID number
- nginx 学习日志(一)
- Nginx 做负载均衡的几种轮询策略
- nginx,php默认配置填坑
- nginx原理及使用
- 超详细的Nginx vhost配置二级域名教程
- 关于php项目需要运行在nginx环境下如何进行本地共享开发
- linux部署nginx的经验
- centos7 uwsgi nginx 部署 python3.6 + django2.2
- nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)
- 详细配置nginx 作为下载服务器,超简单
- centos直接yum安装nginx
- linux系统安装nginx