O Nginx não inicia o Passenger / Nodejs

1

Não consigo que o Passenger inicie meu aplicativo Nodejs (iojs) ao reiniciar o nginx. Eu segui os tutoriais e instalei os pré-requisitos:

$ nginx -V
nginx version: nginx / 1.8.0
configure argumentos: --with -cc-opt = '- g -O2 -fstack-protector --param = ssp-buffer-size = 4 -Formato ……… - add-module = / tmp / buildd / nginx-1.8.0 / debian / modules / passageiro / ext / nginx

no bloco http ativado:

 passenger_root /usr/lib/ruby/vendor_ruby/phusion_passenger/locations.ini;
 passenger_ruby /usr/bin/passenger_free_ruby;
 passenger_nodejs /usr/local/bin/node;
 passenger_default_user staging;
 passenger_default_group www-data;

Em seguida, no bloco do servidor:

upstream instance {
    # point to node instance
    server 127.0.0.1:9000;
}

# for websockets
map $http_upgrade $connection_upgrade {
    default upgrade;
    '' close;
}

server {
    listen 3000;
    server_name localhost;

    set $app_root /home/staging/public_html;

    root $app_root/tmp;
    passenger_enabled on;

    # point to where the app.js file is
    passenger_app_root $app_root;
    passenger_sticky_sessions on;

    location / {
            proxy_pass http://instance;
            proxy_http_version 1.1;
            proxy_set_header X-Forwarded-For  $remote_addr;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection $connection_upgrade;
            proxy_set_header        X-Forwarded-Proto $scheme;
    }

    # all static non-scripts are here
    location /public/ {
        alias $app_root/app/assets/;
    }
}

Então, reiniciando o nginx Eu tento carregar a página & nos logs de erro eu vejo:

… Starting Passenger watchdog...
… Starting Passenger core...
… Passenger core running in multi-application mode.
… Passenger core online, PID 26585
… Starting Passenger UstRouter...
… Passenger UstRouter online, PID 26590
… [error] 26736#0: *3 connect() failed (111: Connection refused) while connecting to upstream, client: 188.102.152.94, server: localhost, request: "GET / HTTP/1.1", upstream: "http://127.0.0.1:9000/", host: "staging.chatterplot.com:3000"

Ir para o URL me dá um gateway ruim para 502.

Eu não vi nenhum exemplo de bloco do servidor nginx que seja semelhante, então tenho a sensação de que estou fazendo algumas coisas muito erradas.

    
por Maruf 28.08.2015 / 10:21

1 resposta

1

Acontece que a razão pela qual o passageiro não estava iniciando foi porque parece que ele requer que o bloco location / não faça o pedido de proxy, mas que ele próprio o controle. A seguinte configuração fez o truque.

map $http_upgrade $connection_upgrade {
    default upgrade;
    '' close;
}

server {
    listen 3000;
    server_name localhost;

    set $app_root /home/user/public_html/dist;
    root $app_root/public;

    passenger_enabled on;
    passenger_sticky_sessions on;
    passenger_app_type node;
    passenger_app_root /home/user/public_html/dist;
    passenger_app_env production;
}

Uma outra coisa que não ficou clara desde o início é que o passageiro / nginx leva o diretório público e torna tudo acessível sem /public na URL.

Portanto, todas as solicitações com /public/images/logo.png são simplesmente /images/logo.png

    
por 01.09.2015 / 12:41