web-dev-qa-db-ja.com

アップストリームへの接続中にconnect()が失敗しました(111:接続が拒否されました)

ディレクトリ内のPHPファイル(502 Gateway)にアクセスするとhttp://example.com/dev/index.phpエラーが発生します。ログには次のように書かれています:

2011/09/30 23:47:54 [error] 31160#0: *35 connect() failed (111: Connection refused) while connecting to upstream, client: xx.xx.xx.xx, server: domain.com, request: "GET /dev/ HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", Host: "domain.com"

これまでに経験したことがありません。このタイプの502 Gatewayエラーの解決策は何ですか?

これはnginx.confです:

user www-data;
worker_processes 4;
pid /var/run/nginx.pid;

events {
    worker_connections 768;
    # multi_accept on;
}

http {

    ##
    # Basic Settings
    ##

    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 65;
    types_hash_max_size 2048;
    # server_tokens off;

    # server_names_hash_bucket_size 64;
    # server_name_in_redirect off;

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

    ##
    # Logging Settings
    ##

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

    ##
    # Gzip Settings
    ##

    gzip on;
    gzip_disable "msie6";

    # gzip_vary on;
    # gzip_proxied any;
    # gzip_comp_level 6;
    # gzip_buffers 16 8k;
    # gzip_http_version 1.1;
    # gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;

    ##
    # Virtual Host Configs
    ##

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

Nginxのバックエンドを開始して構成していないようです。 php-fpmを起動し、httpコンテキストでnginx.confに以下を追加します。

server {
    listen 127.0.0.1;
    server_name localhost;

    error_log /var/log/nginx/localhost.error_log info;

    root /var/www/localhost/htdocs;

    location ~ \.php$ {
        fastcgi_pass 127.0.0.1:9000;
        include /etc/nginx/conf.d/*.conf;
        include /etc/nginx/sites-enabled/*;

        fastcgi_intercept_errors        on;
        error_page 404 /error/404.php;
    }
}
52
quanta

この回答は、次のようなエラーが発生する人のみを対象としています。

アップストリーム、クライアントへの接続中にconnect()が失敗しました(111:接続が拒否されました).... fastcgi:// [:: 1]:9000

DNSではなく、IPを使用するようにnginx設定を書き換えます。例えば、 127.0.0.1の代わりにlocalhostを使用するか、/ etc/hostsからipv6エイリアスを削除します。

53
Quake1TF

このようなエラーも発生しました。問題は、2つのサーバーを参照する抽象的なバックエンドでした。 php-fpmはソケットへのリストのみでした...

# Upstream to abstract backend connection(s) for php
upstream php {
        server unix:/var/run/php5-fpm.sock;
        #server 127.0.0.1:9000;
} 

server {
    [...]

    location ~ \.php$ {
            # NOTE: You should have "cgi.fix_pathinfo = 0;" in php.ini

            # With php5-fpm:
            fastcgi_pass php;
            fastcgi_index index.php;
            fastcgi_intercept_errors on;
            include fastcgi_params;
    }
}
5
KumZ

Nodeポート5000でリッスンしているサーバーへのプロキシされたリクエストで同じ問題がありました。リクエストは_200 OK_で発生しますが、時々_502 Bad Gateway_がランダムに発生します。NGINXはエラーを表示しました:

_connect() failed (111: Connection refused) while connecting to upstream, client: ..., server: ...
_

私の解決策:

  1. ローカルホストをホストとして含めることにより、ノードのHTTPサーバーを listen ipv4に厳密に設定します:server.listen(5000, 'localhost');
  2. Ipv6 listenディレクティブ(_listen [::]:80;_または_listen [::]:443 ssl default_server;_)を削除しました。
  3. IPを使用するようにロケーションブロックproxy_passを変更しました:_proxy_pass http://127.0.0.1:5000_(_proxy_pass http://localhost:5000_ではありません)。

これが誰かを助けることを願っています。

1
Niko Solihin

私の場合、エラーはphp5.6-fpmサービスのerror_logファイルの場所が間違っていたため、php-fpmサービスの開始に失敗しましたおよびnginxは接続できませんでしたit/etc/php/5.6/fpm/php.ini(5.6を実行中のバージョンに置き換えることができます)。

0
George Donev