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


85

私が経験してる502 GatewayディレクトリにPHPファイルにアクセスする際のエラーを(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/*;
}

1
「接続拒否」は、バックエンドがポート9000をリッスンしないか、そのキューがいっぱいになることを意味します。この問題は、バックエンドの問題に関連しています。localhost 9000にtelnetできますか?バックエンドとphpのログも確認する必要があります。
アンドリュー

投稿を更新しました。localhost 9000にtelnetできませんでした
。– MacMac

これは私があなたに直面していた同じエラー、ここではリンクの説明を入力しますが、あなたを助けることができる
Tripathi29

回答:


43

Nginxのバックエンドを開始および構成していないようです。コンテキストでphp-fpm次を開始し、に追加nginx.confhttpます。

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;
    }
}

3
おかげで、うまくいきましたが、php-fpmインストールしていませんでした。乾杯。
MacMac

6
あなたは純粋な天才です。私はこれについて読んだ1.0000000ミリオンのガイドを信じることができません。NOBODYは、バックエンドを有効にするために「listen 127.0.0.1」を置く必要があると述べています。あなたは私を悪夢から救った!

UNIXソケットの使用を検討する必要があります。で表示してnetstat -l確認します/var/run/php5-fpm.sock(この設定は通常/etc/php5/fpm/pool.d/www.confにあります。 fastcgi_pass unix:<socket>
JohannesM

2
あなたが持っていますlisten = /var/run/php5-fpm.sock内部/etc/php5/fpm/pool.d/www.conf。しかし、あなたはしたいlisten = 9000と思います;listen = /var/run/php5-fpm.sock。あなたが私のようだったら。(または、JohannesMの賢明なヒントを聞くこともできます。これはfastcgi_pass unix:/var/run/php5-fpm.sock;、あなたのどこかに何かを残すと思いますnginx.conf
-n611x007

PHP 7.2でも同じ問題が発生します。httpdコンテキストにファイルを追加するとはどういう意味ですか?これは/ etc / nginx / sites-available /フォルダー内の追加のconfファイルでしょうか?
PeterKA

47

この答えは、次のようなエラーが発生した場合のみです。

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

dginではなくipを使用するようにnginx構成を書き換えます。たとえば、の127.0.0.1代わりにlocalhost、/ etc / hostsからipv6エイリアスを削除します。


3
あなたは私を正しい方向に向けた!私はただ使用するだけlisten 80で問題ありませんでした(そして、それに関する多くの例があります)が、IPv4(127.0.0.1)とIPv6([::1])アドレスの両方を暗示しているとは思いませんでした。
グラレイン14

5
からに変更する必要がありlisten 80 default_serverましたlisten 0.0.0.0:80
ギヴァンス14年

これが役立つ理由を指摘できますか?
カイザー

1
ほとんどのLinuxディストリビューションでは、ネットワークでipv6が有効になっていますが、すべてのパケットがipv6用に設定されているわけではありません。私の意見では、nginxがアップストリームへの接続を開始すると、システムリゾルバーは最初にipv6アドレスを返します。Php-fpm(centos 7.x)には、このような設定はありませんでした。そして、ほとんどのガイドは、ipv4バージョンのすべてを説明し、無効にするか使用する必要があるipv6先物を忘れています。
Quake1TF

だから、[:: 1]はローカルホストのIPv6アドレスです!:)ありがとう!
レッシュ

4

このようなエラーも発生しました。問題は、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;
    }
}

1

ポート5000でリッスンしているノードサーバーへのプロキシされたリクエストに同じ問題200 OKがありました。リクエストは、502 Bad Gatewayランダムに発生します。NGINXはエラーを示しました:

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

私の解決策:

  1. ホストとしてlocalhostを含めることにより、ipv4を厳密にリッスンするようにノードHTTPサーバーを設定します。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(not proxy_pass http://localhost:5000)。

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


0

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


-1

ちょうど今日、私はこの問題に遭遇しました、そして、私にとって、それは高負荷期間の間の低メモリ問題でした。したがって、インスタンスタイプをレベルアップすると、問題が修正されました。


-4

同じ問題があり、listenステートメントを追加しました

listen 127.0.0.1;

私のために働いた。

興味深いことに、これなしで非常にうまく実行されている他のサーバーブロックがあります。


3
これは3年前に既に回答され、受け入れられています。
スヴェン
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.