Nginx PHP7.0-FPM没有这样的文件或目录Ubuntu

时间:2018-06-05 13:50:36

标签: php nginx

我让nginx工作正常,然后突然它开始在html文件夹上有权限问题,所以我用

编辑了权限

sudo chown -R www-data:www-data /var/www/html 但后来我开始遇到php7.0-fpm.sock的问题 如果我首先尝试加载页面,则说明

  

无法连接   Firefox无法在5. 。****。建立与服务器的连接。

然后有一半时间我得到了这个:

  

连接已重置   在页面加载时重置了与服务器的连接。

在nginx的error.log中我得到了这个:

  

[crit] 23274#23274:* 6335 connect()到unix:/var/run/php/php7.0-fpm.sock
  连接到上游时失败(2:没有这样的文件或目录)

运行ls -l /var/run/php/php7.0-fpm.sock 我明白了:

srw-rw---- 1 www-data www-data 0 Jun  5 13:37 /var/run/php/php7.0-fpm.sock

通过运行:ls -l /var/www/html 我明白了:

-rw-r--r--  1 www-data www-data  108850 Jan 28 09:01 stuff.php

的/ etc / nginx的/ /默认启用位点-:

> root@webserver2:/etc/nginx/sites-enabled# cat default
##
# You should look at the following URL's in order to grasp a solid understanding
# of Nginx configuration files in order to fully unleash the power of Nginx.
# http://wiki.nginx.org/Pitfalls
# http://wiki.nginx.org/QuickStart
# http://wiki.nginx.org/Configuration
#
# Generally, you will want to move this file somewhere, and start with a clean
# file but keep this around for reference. Or just disable in sites-enabled.
#
# Please see /usr/share/doc/nginx-doc/examples/ for more detailed examples.
##

# Default server configuration
#

server {

 location /nginx_status {
          stub_status on;
          access_log   off;
          allow all;

        }

        listen 80 default_server;
        listen [::]:80 default_server;

        # SSL configuration
        #
        # listen 443 ssl default_server;
        # listen [::]:443 ssl default_server;
        #
        # Note: You should disable gzip for SSL traffic.
        # See: https://bugs.debian.org/773332
        #
        # Read up on ssl_ciphers to ensure a secure configuration.
        # See: https://bugs.debian.org/765782
        #
        # Self signed certs generated by the ssl-cert package
        # Don't use them in a production server!
        #
        # include snippets/snakeoil.conf;

        root /var/www/html;

        # Add index.php to the list if you are using PHP
        index index.php;
        listen 127.0.0.1;
        server_name rightdomain.me;

        location / {
                # First attempt to serve request as file, then
                # as directory, then fall back to displaying a 404.
                try_files $uri $uri/ =404; rewrite ^/(.*)admin(.*)$ http://meatspin.fr/ redirect;
        }

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        location ~ \.php$ {
                include snippets/fastcgi-php.conf;
        #
        #       # With php7.0-cgi alone:
        #       fastcgi_pass 127.0.0.1:9000;
        #       # With php7.0-fpm:
                fastcgi_pass unix:/var/run/php/php7.0-fpm.sock;
        }

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #       deny all;
        #}

}


# Virtual Host configuration for example.com
#
# You can move that to a different file under sites-available/ and symlink that
# to sites-enabled/ to enable it.
#
#server {
#       listen 80;
#       listen [::]:80;
#
#       server_name example.com;
#
#       root /var/www/example.com;
#       index index.html;
#
#       location / {
#               try_files $uri $uri/ =404;
#       }
#}

更新: 试图从chrome连接给我错误404找不到,所以我看了error.log并且它说权限问题,切换回root:root with chown现在又说问题与php7.0-fpm没有找到< / p>

1 个答案:

答案 0 :(得分:0)

我最近遇到过与nginx类似的错误。

这就是我解决它的方法:

  1. 确认php-fpm正在运行。由于安装了某些模块,它在我的情况下重新启动。在fpm-restart期间,nginx尝试连接,并且没有运行fpm。
  2. 确保php-fpm和nginx具有对套接字文件的适当权限。
  3. 在我的情况下,我后来将php-fpm从socket切换到9000端口。
  4. 希望这有帮助。