nginx: FastCGI enviado em stderr: “Script primário desconhecido”

1

Usando a versão mais recente do nginx (1.10.0) e do php-fpm (PHP 7.0.6) no arch linux de 64 bits.

Ao tentar solicitar index.php para uma instalação do DokuWiki, recebo o seguinte erro:

2016/05/21 22:09:50 [error] 11099#11099: *1 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: 192.168.70.3, server: doku.test.com, request: "GET /install.php HTTP/1.1", upstream: "fastcgi://unix:/run/php-fpm/php-fpm.sock:", host: "doku.test.com"

Aqui está a configuração relevante do servidor:

server {
  listen 80;
  server_name doku.test.com;
  root /var/www/doku/public_html/;
  access_log /var/log/nginx/scripts.log scripts;

  location ~ \.php$ {
    include fastcgi_params;
    fastcgi_pass  unix:/run/php-fpm/php-fpm.sock;
    fastcgi_index index.php;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  }

}

Aqui está o fastcgi_params:

fastcgi_param  QUERY_STRING       $query_string;
fastcgi_param  REQUEST_METHOD     $request_method;
fastcgi_param  CONTENT_TYPE       $content_type;
fastcgi_param  CONTENT_LENGTH     $content_length;

fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;
fastcgi_param  REQUEST_URI        $request_uri;
fastcgi_param  DOCUMENT_URI       $document_uri;
fastcgi_param  DOCUMENT_ROOT      $document_root;
fastcgi_param  SERVER_PROTOCOL    $server_protocol;
fastcgi_param  REQUEST_SCHEME     $scheme;
fastcgi_param  HTTPS              $https if_not_empty;

fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;
fastcgi_param  SERVER_SOFTWARE    nginx/$nginx_version;

fastcgi_param  REMOTE_ADDR        $remote_addr;
fastcgi_param  REMOTE_PORT        $remote_port;
fastcgi_param  SERVER_ADDR        $server_addr;
fastcgi_param  SERVER_PORT        $server_port;
fastcgi_param  SERVER_NAME        $server_name;

# PHP only, required if PHP was built with --enable-force-cgi-redirect
fastcgi_param  REDIRECT_STATUS    200;

Como pode ser visto na minha configuração do servidor, estou tentando registrar a saída do parâmetro SCRIPT_FILENAME , já que toda a minha pesquisa parece estar apontando para isso como o culpado. Aqui está a parte relevante do nginx.conf:

log_format scripts '$document_root$fastcgi_script_name > $request';

Ao solicitar a página index.php, o abaixo é gerado em scripts.log :

/var/www/doku/public_html/index.php > GET /index.php HTTP/1.1

Fazendo um ls nesse arquivo:

-rwxr-xr-x 1 nginx nginx 182 May 21 06:45 /var/www/doku/public_html/index.php

Vale notar que tanto o daemon nginx quanto o daemon do php-fpm estão configurados para rodar como o usuário nginx usando o grupo nginx. Não entendo por que estou obtendo o erro inicial, pois o registro de log está efetivamente comprovado que SCRIPT_FILENAME está de fato apontando para o caminho correto.

De todas as respostas ServerFault que eu revisei, adicionando que param para a configuração do servidor parecia ser a solução número 1 para o meu erro, mas não parece corrigi-lo no meu caso.

Alguma sugestão?

    
por Joshua Gilman 22.05.2016 / 07:34

1 resposta

0

Primeiro, verifique se você definiu o endereço de atendimento correto em seu arquivo www.conf para o PHP-FPM (FastCGI Process Manager). Então abra o arquivo www.conf (location: /etc/php5/fpm/pool.d/www.conf ) e ele deverá ver algo assim:

Start a new pool named 'www'.
[www]

;prefix = /path/to/pools/$pool

user = www-data
group = www-data

listen = 127.0.0.1:8080

; Set permissions for unix socket, if one is used. In Linux, read/write
; permissions must be set in order to allow connections from a web server. Many
; BSD-derived systems allow connections regardless of permissions. 
; Default Values: user and group are set as the running user
;                 mode is set to 0660
listen.owner = www-data
listen.group = www-data
listen.mode = 0660

Sob o endereço de escuta, verifique se você definiu o endereço de loopback (identifica seu servidor) e o número da porta. Em seguida, em sua nginx.conf alteração do arquivo fastcgi_pass to 127.0.0.1:8080 , então, no final, ele deve se parecer com:

server {
  listen 80;
  server_name doku.test.com;
  root /var/www/doku/public_html/;
  access_log /var/log/nginx/scripts.log scripts;

  location ~ \.php$ {
    include fastcgi_params;
    fastcgi_pass  127.0.0.1:8080;
    fastcgi_index index.php;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  }

}

Observe que usei a porta 8080 no exemplo, talvez seja necessário codificá-la.

    
por 22.05.2016 / 12:18