Nginx与php7.1-fpm显示空白的php页面

时间:2017-09-24 22:12:23

标签: nginx php-7.1

背景&环境

我正按照herehere的说明尝试使用PHP7.1-FPM部署Nginx服务器:

  • 服务器是Ubuntu 16.04
  • Nginx版本为1.13.3
  • PHP版本是 PHP 7.1.9-1+ubuntu16.04.1+deb.sury.org+1 (cli) (built: Sep 2 2017 05:56:43) ( NTS )

我对这一切都很陌生,所以与一位经验丰富的Linux管理员相比,我仍然对某些事情一无所知,但我知道它足以处理基础知识。

问题

当我浏览到inspired01.DOMAIN.com/application/的网址时,我会看到一个空白页面。 nginx错误日志中没有条目。

当我浏览inspired01.DOMAIN.com/application/index.php之类的网址时,我收到了404错误。

到目前为止已经尝试了

我在stackoverflow帖子here中尝试了这些建议。据我所知,我的配置已经有人建议的条目为他们解决了这个问题。

我无法用这些答案解决问题。由于该职位已有几年历史,我想也许从那以后需求发生了变化。

我的Nginx配置

我的nginx.conf是:

user inspired786;
worker_processes auto;
pid /run/nginx.pid;
include /etc/nginx/modules-enabled/*.conf;

events {
    worker_connections 1024;
    multi_accept on;
}

http { 
    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 25;
    types_hash_max_size 2048;
    server_tokens off;
    client_max_body_size 64m;

    include /etc/nginx/mime.types;
    default_type application/octet-stream;

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
    ssl_prefer_server_ciphers on;

    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;

    gzip on;
    gzip_disable "msie6";

    gzip_proxied any;
    gzip_comp_level 2;
    gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

    # Virtual Host Configs

    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;

server {
    listen 80 default_server;
    listen [::]:80 default_server;
    server_name _;
    return 444;
    }
}

网站的配置文件是:

server {
    listen 80;
    listen [::]:80;

    server_name inspired01.DOMAIN.com;

    access_log /home/inspired786/DOMAIN.com/logs/access.log;
    error_log /home/inspired786/DOMAIN.com/logs/error.log;

    root /home/inspired786/DOMAIN.com/public/;
    index index.php;

    location / {
        try_files $uri $uri/ /index.php?$args;
    }

    location ~ \.php$ {
        try_files $uri =404;
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        fastcgi_pass unix:/run/php/php7.1-fpm.sock;
        fastcgi_index index.php;
        include fastcgi_params;
    }
}

日志

Nginx服务器或站点日志中未生成任何条目。

/var/log/php7.1-fpm.log

的FPM日志中没有记录相关条目

问题

我想知道这个配置中是否有任何明显的遗漏或错误,这可能会导致php文件无法解析。

更新

根据下面的评论,贴在这里所以任何新人都会看到它:

  

我启用了debug_connection并完成了大量的日志输出   那产生了。据我所知,没有问题   报道。好吧,没有明显的errorswarnings。所以我创建了一个   基本hello.php文件,包括基本的echo命令,以及   的phpinfo。该文件工作正常。所以我怀疑这个问题是有道理的   其他。继续调查。

现在暂时考虑这个问题,同时我会研究空白页问题的其他可能性。

2 个答案:

答案 0 :(得分:0)

我在Linux 2.6,PHP5和nginx上运行 我的PHP文件显示为文本

经过多次测试后,我更改了默认文件 \用户名\启用站点等\ nginx的\:C 如下:

location ~ [^/]\.php(/|$) {
  fastcgi_split_path_info ^(.+\.php)(/.+)$;
  include fastcgi_params;
  # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini
  # With php5-cgi alone:
  fastcgi_pass 127.0.0.1:9000;
  # With php5-fpm:
  #fastcgi_pass unix:/var/run/php5-fpm.sock;
  fastcgi_index index.php;
  fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;
}

重启nginx和PHP服务后,PHP开始工作了!

检查您的php文件是否在默认文件中设置的根路径下 并使用test.php文件开始测试,如下所示:

<?php
/* test.php */
  phpinfo();
?>

答案 1 :(得分:0)

尝试修复项目目录中的权限。在Linux中,这对我有用:

sudo chown -R www-data:www-data .