업스트림에 연결하는 동안 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을 수신하지 않거나 해당 큐가 채워져 있음을 의미합니다. 이 문제는 백엔드 itsef와 관련이 있습니다. localhost 9000을 Telnet 할 수 있습니까? 백엔드 및 PHP 로그도 확인해야합니다.
앤드류

내 게시물을 업데이트했습니다. localhost 9000에 텔넷으로 연결할 수 없습니다.
MacMac

내가
겪었던

답변:


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
당신은 순수한 천재입니다. NOBODY는 백엔드를 활성화하기 위해 "들어오는 127.0.0.1"을 넣어야한다고 언급합니다. 당신은 악몽에서 나를 구 했어요 !!!

유닉스 소켓 사용을 고려해야합니다. 함께 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

이 답변은 다음과 같은 오류가있는 사람들에게만 해당됩니다.

업스트림, 클라이언트에 연결하는 동안 connect () 실패 (111 : 연결 거부) .... fastcgi : // [:: 1] : 9000

dns가 아닌 ip를 사용하도록 nginx 구성을 다시 작성하십시오. 예를 들어, 127.0.0.1대신 localhost/ etc / hosts에서 ipv6 별명을 제거하십시오.


3
당신은 나의 올바른 방향을 가리 켰습니다! 나는 사용하는 listen 80것이 좋지만 (그리고 거기에 많은 예제가 있지만 127.0.0.1) IPv4 ( )와 IPv6 ( [::1]) 주소를 모두 암시한다고 생각하지 않았습니다 .
glarrain

5
에서로 변경 listen 80 default_server해야했습니다 listen 0.0.0.0:80.
givanse

이것이 왜 도움이 되는지 지적 할 수 있습니까 ?
카이저

1
대부분의 Linux 배포판은 네트워킹에서 ipv6을 활성화했지만 ipv6 용으로 구성된 모든 패킷이 아닙니다. 내 생각에, nginx가 업스트림에 연결을 시작할 때 시스템 리졸버는 먼저 ipv6 주소를 반환합니다. Php-fpm (centos 7.x)에는 상자에서 이러한 설정이 없었습니다. 그리고 대부분의 가이드는 ipv4 버전에서 모두 설명하고 비활성화하거나 사용해야하는 ipv6 선물을 잊어 버립니다.
Quake1TF

Whooah, 따라서 [:: 1]은 localhost IPv6 주소입니다! :) 감사!
lechup

4

이와 같은 오류가 있습니다. 문제는 두 서버를 참조하는 내 추상 백엔드였습니다. 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 [::]:80;또는 listen [::]:443 ssl default_server;)을 제거했습니다 .
  3. IP를 사용하도록 위치 블록 proxy_pass가 변경되었습니다 : proxy_pass http://127.0.0.1:5000(아님 proxy_pass http://localhost:5000).

이것이 누군가를 돕기를 바랍니다.


0

내 경우에는 오류가 상기의 error_log php5.6-FPM 서비스에 대한 파일 및 따라서에 대한 나쁜 위치했다 PHP-FPM 서비스를 시작 실패했다의 nginx가에 연결할 수 없습니다 . 찾을 수 있습니다 /etc/php/5.6/fpm/php.ini(5.6을 실행중인 버전으로 바꿀 수 있음).


-1

바로 오늘이 문제에 부딪 쳤고로드 기간 동안 메모리 부족 문제였습니다. 따라서 인스턴스 유형을 높이면 문제가 해결되었습니다.


-4

나는 같은 문제가 있었고 청취 진술을 추가했다.

listen 127.0.0.1;

나를 위해 일했다.

흥미롭게도 나는 이것없이 아주 행복하게 실행되는 다른 서버 블록을 가지고 있습니다!


3
이것은 이미 3 년 전에 이미 답변을 받았으며 받아 들여졌습니다.
Sven
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.