zoukankan      html  css  js  c++  java
  • Nginx+PHP配置错误,日志:[error] 24324#0: *31 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream

    一、问题现象

    1、安装nginx、php、php-fpm后,浏览器访问php报错,“File not found”;

    二、问题排查

    1、检查nginx、php-fpm服务是否正常启动,均正常启动;

    2、检查服务端口号,分别是nginx:81、php:9000

     

    3、查看nginx错误日志 /usr/local/nginx/logs/error.log   tail -n 20 error.log

    [error] 24324#0: *31 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream

    三、解决方法

    1、粘贴错误日志信息到百度,发现是nginx配置文件缺少参数导致,参考链接https://www.cnblogs.com/php-linux/p/6526641.html

    首先简单的讲一讲原理,目前主流的nginx+php的运行原理如下:
    1> nginx的worker进程直接管理每一个请求到nginx的网络请求。
    2> 对于php而言,由于在整个网络请求的过程中php是一个cgi程序的角色,所以采用名为php-fpm的进程管理程序来对这些被请求的php程序进行管理。php-fpm程序也如同nginx一样,需要监听端口,并且有master和worker进程。worker进程直接管理每一个php进程。
    3> 关于fastcgi:fastcgi是一种进程管理器,管理cgi进程。市面上有多种实现了fastcgi功能的进程管理器,php-fpm就是其中的一种。再提一点,php-fpm作为一种fast-cgi进程管理服务,会监听端口,一般默认监听9000端口,并且是监听本机,也就是只接收来自本机的端口请求,所以我们通常输入命令 netstat -nlpt|grep php-fpm 会得到:
    tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      1057/php-fpm
    这里的127.0.0.1:9000 就是监听本机9000端口的意思。
    4> 关于fastcgi的配置文件,目前fastcgi的配置文件一般放在nginx.conf同级目录下,配置文件形式,一般有两种:fastcgi.conf  和 fastcgi_params。不同的nginx版本会有不同的配置文件,这两个配置文件有一个非常重要的区别:fastcgi_parames文件中缺少下列配置:
    fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name;
    我们可以打开fastcgi_parames文件加上上述行,也可以在要使用配置的地方动态添加。使得该配置生效。
    5> 当需要处理php请求时,nginx的worker进程会将请求移交给php-fpm的worker进程进行处理,也就是最开头所说的nginx调用了php,其实严格得讲是nginx间接调用php。
     

    2、修改nginx.conf配置文件,添加 fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name; 到文件中;

    1> 第一个大括号 server{ }:不必多说,代表一个独立的server,
    2> listen  8011:代表该server监听8011端口 
    3> location ~ .php?.*${ }:代表一个能匹配对应uri的location,用于匹配一类uri,并对所匹配的uri请求做自定义的逻辑、配置。这里的location,匹配了所有带.php的uri请求,例如:http://192.168.244.128:8011/test.php/asdasd  http://192.168.244.128:8011/index.php等
    4> root  /share/test:请求资源根目录,告诉匹配到该location下的uri到/share/test文件夹下去寻找同名资源。
    5> fastcgi_pass  127.0.0.1:9000:这行开始是本文的重点:这行代码的意思是,将进入到该location内的uri请求看做是cgi程序,并将请求发送到9000端口,交由php-fpm处理。
    6> fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;  :这行配置意思是:动态添加了一行fastcgi配置,配置内容为SCRIPT_FILENAME,告知管理进程,cgi脚本名称。由于我的nginx中只有fastcgi_params文件,没有fastcgi.conf文件,所以要使php-fpm知道SCRIPT_FILENAME的具体值,就必须要动态的添加这行配置。
    7> include fastcgi_params; 引入fastcgi配置文件
    以上就是最简洁版的nginx启动php脚本的最简配置,当重启nginx之后,在/share/test目录下创建一个xx.php文件,输入<?php  echo "hello world"; ?>保存,然后在浏览器中访问localhost:8011/xx.php 就可以在网页上显示hello world了。
     
    四、问题验证
    1、修改nginx配置文件nginx.conf;

    2、重启nginx服务,浏览器访问php文件,成功。

     
  • 相关阅读:
    codeforces 407B Long Path
    CodeForces 489C Given Length and Sum of Digits...
    hacker cup 2015 Round 1 解题报告
    hacker cup 2015 资格赛
    Codeforces 486(#277 Div 2) 解题报告
    POJ 3468 A Simple Problem with Integers splay
    Codeforces 484(#276 Div 1) D Kindergarten DP
    求平均值问题201308031210.txt
    I love this game201308022009.txt
    QQ
  • 原文地址:https://www.cnblogs.com/lwhctv/p/9132749.html
Copyright © 2011-2022 走看看