错误28105#0:* 1在stderr中发送的FastCGI:"主要脚本未知"从上游读取响应头

时间:2015-04-28 09:13:50

标签: nginx docker virtualhost php

我无法正确配置Nginx php-fpm。当我得到任何PHP脚本时,我在浏览器中收到Nginx 404 Not found错误:

File not found.

在我的php-fpm日志中,我得到了:

172.17.42.1 -  28/Apr/2015:09:15:15 +0000 "GET /index.php" 404

对于任何php脚本调用,在Nginx日志中我得到:

[error] 28105#0: *1 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: 127.0.0.1, server: localhost, request: "GET /index.php HTTP/1.1", upstream: "fastcgi://127.168.66.66:9000", host: "localhost"

我的Nginx vitualhost配置是:

server {
  listen 80;

  root /var/www/html;
  index index.html;

  server_name localhost;

  location / {
    # First attempt to serve request as file, then
    # as directory, then fall back to displaying a 404.
    try_files $uri $uri/ =404;
  }

  location ~* \.php$ {
    fastcgi_index   index.php;
    fastcgi_pass    127.168.66.66:9000;
    #fastcgi_pass    unix:/var/run/php5-fpm.sock;
    include         fastcgi_params;
    fastcgi_param   SCRIPT_FILENAME    $document_root$fastcgi_script_name;
    fastcgi_param   SCRIPT_NAME        $fastcgi_script_name;
  }
}

我从official php repository开始运行php-fpm Docker镜像,运行方式为:

docker run -it -p 127.168.66.66:9000:9000 php:fpm

docker ps命令显示下一个信息:

CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS                          NAMES
dbf9f7d1c6f9        php:fpm             "php-fpm"           8 seconds ago       Up 7 seconds        127.168.66.66:9000->9000/tcp   serene_curie 

我的配置有什么问题?

P.S。任何静态文件(css,js,images)都适用于Nginx。

1 个答案:

答案 0 :(得分:6)

此外,还需要将文件共享到php:fpm docker容器。答案是使用卷运行docker php:fpm图像:

docker run -it -p 127.168.66.66:9000:9000 -v /var/www/html/:/var/www/html/ php:fpm