PHP Primary script unknown 终极解决方法

相信很多配置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.

原因只有两个,一个是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 = phpusergroup = 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 wwwphpuser  19109  0.0  0.1 207644  7112 ?        S    1月02   0:00 php-fpm: pool wwwroot     24676  0.0  0.0  56660  1024 ?        Ss   13:08   0:00 nginx: master process /usr/sbin/nginx -c /etc/nginx/nginx.confphpuser  24677  0.0  0.7  84680 29976 ?        S    13:08   0:00 nginx: worker processphpuser  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: masttcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      24676/nginx: mastertcp6       0      0 :::80                   :::*                    LISTEN      24676/nginx: master

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

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

还有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 /usrdrwxr-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/htmldrwxr-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

 

 

 

未经允许不得转载:PHP100中文网 - 中国第一档PHP资源分享门户 » PHP Primary script unknown 终极解决方法

赞 (1) 打赏

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏