PHP Primary script unknown 解决方法总结


Posted in PHP onAugust 22, 2019

相信很多配置php环境的都遇到过这个恼人的问题:

  • 浏览器访问php文件,返回来 File not found
  • 查看/var/log/nginx/error.log ,有 “Primary script unknown”,类似如下:
2019/01/03 10:24:02 [error] 11931#11931: *260 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream,
client: 1.2.3.4, server: localhost, request: "GET /index.php HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host: www.example.com

原因只有两个,一个是php-fpm找不到php文件,一个是php-fpm没有权限读取和执行文件。

1. 找不到文件问题

nginx 的站点配置文件php段要这样:

# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
  location ~ \.php$ {    #root 路径配置必须要有,而且必须要写对(别笑,真的能写错)
    root      /usr/share/nginx/html;
    fastcgi_pass  127.0.0.1:9000;
    fastcgi_index index.php;    #SCRIPT_FILENAME用$document_root,而不是具体路径
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    include    fastcgi_params;
  }

2. 权限问题

也是坑最多的。

1) 进程用户

nginx.conf 里的 user 配置要跟 php-fpm.d/www.conf 一致,比如都用 nginx,或者自定义用户 phpuser(再来句废话,这个用户需要提前建好)。

nginx.conf :

user phpuser;
worker_processes auto;

php-fpm.d/www.conf :

; Unix user/group of processes
; Note: The user is mandatory. If the group is not set, the default user's group
;    will be used.
user = phpuser
group = phpuser

nginx 和 php-fpm 进程/监听信息:

root   19107 0.0 0.1 207644 5852 ?    Ss  1月02  0:03 php-fpm: master process (/usr/local/etc/php-fpm.conf)
phpuser 19108 0.0 0.1 207644 7108 ?    S  1月02  0:00 php-fpm: pool www
phpuser 19109 0.0 0.1 207644 7112 ?    S  1月02  0:00 php-fpm: pool www
root   24676 0.0 0.0 56660 1024 ?    Ss  13:08  0:00 nginx: master process /usr/sbin/nginx -c /etc/nginx/nginx.conf
phpuser 24677 0.0 0.7 84680 29976 ?    S  13:08  0:00 nginx: worker process
phpuser 24678 0.0 0.7 84324 29236 ?    S  13:08  0:00 nginx: worker process
tcp    0   0 127.0.0.1:9000     0.0.0.0:*        LISTEN   19107/php-fpm: mast
tcp    0   0 0.0.0.0:80       0.0.0.0:*        LISTEN   24676/nginx: master
tcp6    0   0 :::80          :::*          LISTEN   24676/nginx: master

如果修改了 nginx 运行用户还必须要改些目录权限:

chown -R phpuser:phpuser /var/log/nginx
chown -R phpuser:phpuser /var/cache/nginx
chown -R phpuser:phpuser /usr/share/nginx/html

还有/etc/logrotate.d/nginx,create 640 nginx adm 这行要改:

create 640 phpuser adm

2) 目录和文件权限

php文件不必非得设为 777,让人怪担心的,只要是nginx和php-fpm运行用户可读写执行即可,一般可以770 。

php文件目录和文件样例:

drwxrwx--- 6 phpuser phpuser 4.0K 2019-01-03 13:09 /usr/share/nginx/html
-rwxrwx--- 1 phpuser phpuser 40  2019-01-03 13:09 /usr/share/nginx/html/phpinfo.php

这里有个深坑,对于使用其他目录放置php文件的很可能中招,就是 /path/to/phpfiles 的每一层目录都要允许 phpuser 访问,缺一层就会 Permission denied。

本例,/usr/share/nginx/html 之上的每一层目录,所有者都是root,都有 o+rx ,即所有人都有读取和执行权限(读取和执行权限是目录访问的根本),因此 phpuser 可以访问到 html 目录。

drwxr-xr-x. 13 root root    155 2018-07-10 15:42 /usr
drwxr-xr-x. 86 root root    4.0K 2018-12-17 07:33 /usr/share/
drwxr-xr-x  4 root root     40 2018-12-17 08:06 /usr/share/nginx/
drwxrwx---  6 phpuser phpuser 4.0K 2019-01-03 13:11 /usr/share/nginx/html/

测试方法:

sudo -u phpuser ls -l /usr/share/nginx/html/

3) SELINUX

nginx/apache 网页文件的 selinux 上下文,如果更换目录需要配上。(在Cenots7+php7.3上测试,没有 selinux 上下文时,静态文件404,而php文件反倒没有遇到问题,没有深究)

# ll -dZ /usr/share/nginx/html
drwxr-xr-x. root root system_u:object_r:httpd_sys_content_t:s0 /usr/share/nginx/html

配置 selinux 上下文:

chcon -R -t httpd_sys_content_t /path/to/phpfiles

或者干脆关闭selinux(需要重启服务器)

/etc/selinux/config :

SELINUX=disabled

3. 最后

echo "<p align='center'>Good Luck :)</p><?php phpinfo(); ?>" > /usr/share/nginx/html/phpinfo.php

以上就是PHP Primary script unknown 终极解决方法的全部知识点内容,感谢大家对三水点靠木的支持。

PHP 相关文章推荐
window+nginx+php环境配置 附配置搭配说明
Dec 29 PHP
PHP学习笔记之二
Jan 17 PHP
php环境配置之CGI、FastCGI、PHP-CGI、PHP-FPM、Spawn-FCGI比较?
Oct 17 PHP
php中如何防止表单的重复提交
Aug 02 PHP
Codeigniter实现多文件上传并创建多个缩略图
Jun 12 PHP
php三元运算符知识汇总
Jul 02 PHP
Thinkphp3.2.3整合phpqrcode生成带logo的二维码
Jul 21 PHP
ThinkPHP5实现作业管理系统中处理学生未交作业与已交作业信息的方法
Nov 12 PHP
php 广告点击统计代码(php+mysql)
Feb 21 PHP
微信公众平台开发教程①获取用户Openid及个人信息图文详解
Apr 10 PHP
php 多继承的几种常见实现方法示例
Nov 18 PHP
php下的原生ajax请求用法实例分析
Feb 28 PHP
php用wangeditor3实现图片上传功能
Aug 22 #PHP
PHP生成zip压缩包的常用方法示例
Aug 22 #PHP
Laravel 实现数据软删除功能
Aug 21 #PHP
PHP针对redis常用操作实例详解
Aug 17 #PHP
php5.6.x到php7.0.x特性小结
Aug 17 #PHP
PHP中非常有用却鲜有人知的函数集锦
Aug 17 #PHP
PHP中Session ID的实现原理实例分析
Aug 17 #PHP
You might like
关于页面优化和伪静态
2009/10/11 PHP
php Xdebug 调试扩展的安装与使用.
2010/03/13 PHP
队列在编程中的实际应用(php)
2010/09/04 PHP
解析php做推送服务端实现ios消息推送
2013/07/01 PHP
利用浏览器的Javascript控制台调试PHP程序
2014/01/08 PHP
header导出Excel应用示例
2014/01/24 PHP
php格式化时间戳显示友好的时间实现思路及代码
2014/10/23 PHP
WordPress中查询文章的循环Loop结构及用法分析
2015/12/17 PHP
PHP版单点登陆实现方案的实例
2016/11/17 PHP
Angular用来控制元素的展示与否的原生指令介绍
2015/01/07 Javascript
jQuery仿360导航页图标拖动排序效果代码分享
2015/08/24 Javascript
js仿3366小游戏选字游戏
2016/04/14 Javascript
javascript 小数乘法结果错误的处理方法
2016/07/28 Javascript
原生JS获取元素的位置与尺寸实现方法
2017/10/18 Javascript
JS模拟实现哈希表及应用详解
2018/05/04 Javascript
解决vue中修改export default中脚本报一大堆错的问题
2018/08/27 Javascript
js常用正则表达式集锦
2019/05/17 Javascript
9个JavaScript日常开发小技巧
2020/10/06 Javascript
[04:20]DOTA2-DPC中国联赛 正赛 VG vs LBZS 选手采访 1月19日
2021/03/11 DOTA
让python json encode datetime类型
2010/12/28 Python
Django框架中数据的连锁查询和限制返回数据的方法
2015/07/17 Python
在windows系统中实现python3安装lxml
2016/03/23 Python
Django 如何获取前端发送的头文件详解(推荐)
2017/08/15 Python
Python实现通过解析域名获取ip地址的方法分析
2019/05/17 Python
如何基于Python获取图片的物理尺寸
2019/11/25 Python
在python3.9下如何安装scrapy的方法
2021/02/03 Python
html5使用canvas绘制文字特效
2014/12/15 HTML / CSS
自荐信格式的六要素
2013/09/21 职场文书
室内设计专业自荐信
2014/05/31 职场文书
财务会计实训报告
2014/11/05 职场文书
2015年上半年党建工作总结
2015/03/30 职场文书
培训讲师开场白
2015/06/01 职场文书
php 原生分页
2021/04/01 PHP
Go语言基础map用法及示例详解
2021/11/17 Golang
Java设计模式之享元模式示例详解
2022/03/03 Java/Android
Python利用FlashText算法实现替换字符串
2022/03/31 Python