资讯专栏INFORMATION COLUMN

PHP Primary script unknown 终极解决方法

sixleaves / 3321人阅读

摘要:找不到文件问题的站点配置文件段要这样路径配置必须要有,而且必须要写对别笑,真的能写错用,而不是具体路径权限问题也是坑最多的。本例,之上的每一层目录都有,所以可以访问到目录。测试方法网页文件的上下文,如果更换目录需要配上。

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

浏览器访问php文件,返回来 File not found

查看/var/log/nginx/error.log ,有 “Primary script unknown”,类似如下:

</>复制代码

  1. 2019/01/03 10:24:02 [error] 11931#11931: *260 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream,
  2. 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段要这样:

</>复制代码

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

也是坑最多的。

1) 进程用户

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

nginx.conf :

</>复制代码

  1. user phpuser;
  2. worker_processes auto;

php-fpm.d/www.conf :

</>复制代码

  1. ; Unix user/group of processes
  2. ; Note: The user is mandatory. If the group is not set, the default user"s group
  3. ; will be used.
  4. user = phpuser
  5. group = phpuser

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

</>复制代码

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

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

</>复制代码

  1. chown -R phpuser:phpuser /var/log/nginx
  2. chown -R phpuser:phpuser /var/cache/nginx
  3. chown -R phpuser:phpuser /usr/share/nginx/html

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

</>复制代码

  1. create 640 phpuser adm
2) 目录和文件权限

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

php文件目录和文件样例:

</>复制代码

  1. drwxrwx--- 6 phpuser phpuser 4.0K 2019-01-03 13:09 /usr/share/nginx/html
  2. -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 之上的每一层目录都有 o+rx,所以 phpuser 可以访问到 html 目录。

</>复制代码

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

测试方法:

</>复制代码

  1. sudo -u phpuser ls -l /usr/share/nginx/html/
3) SELINUX

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

</>复制代码

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

配置 selinux 上下文:

</>复制代码

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

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

</>复制代码

  1. SELINUX=disabled
3. 最后

</>复制代码

  1. echo "

    Good Luck :)

    " > /usr/share/nginx/html/phpinfo.php

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/29889.html

相关文章

  • PHP Primary script unknown 终极解决方法

    摘要:找不到文件问题的站点配置文件段要这样路径配置必须要有,而且必须要写对别笑,真的能写错用,而不是具体路径权限问题也是坑最多的。本例,之上的每一层目录都有,所以可以访问到目录。测试方法网页文件的上下文,如果更换目录需要配上。 相信很多配置php环境的都遇到过这个恼人的问题: 浏览器访问php文件,返回来 File not found 查看/var/log/nginx/error.log ...

    lemon 评论0 收藏0
  • 记一次Nginx-Primary script unknown的报错解决

    摘要:报错在的中遭到定义脚本文件的地方修改成如下方式代表当前请求在指令中指定的值上面配置中的就是针对目录下的文件进行解析。 报错: [error] 12691#0: *6 FastCGI sent in stderr: Primary script unknown while reading response header from upstream, client: 192.168.168...

    graf 评论0 收藏0
  • 不一样的nginx报错"Primary script unknown"

    摘要:昨天晚上忘记对开发环境做了什么改动,导致今天来了在进行接口调试的时候提示这个大多数情况下来说是一个很简单的问题配置里面的错误。然而我检查了我的配置,发现并没有什么问题。 昨天晚上忘记对开发环境做了什么改动,导致今天来了在进行接口调试的时候nginx提示Primary script unknown,这个大多数情况下来说是一个很简单的问题:nginx配置里面的script_filename...

    simpleapples 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<