spawn-fcgi + multiwatch + nginx + ruby: os trabalhadores não respondem

1

Eu fiz um site com Ruby e FastCGI, e funciona muito bem com o Apache. Eu gostaria de mudar para o nginx, mas não consigo trabalhar.

O site é feito de dois processos: um cuida de chamadas AJAX, o outro cuida do resto.

Até agora, descobri que deveria usar o spawn-fcgi para iniciar meus trabalhadores e ligá-los a uma tomada. Porque eu gostaria de ter vários funcionários, também uso o multiwatch.

O problema é que sempre que tento acessar uma página, recebo um erro 502 e a seguinte linha em error.log:

2013/04/03 23:58:39 [error] 1450#0: *1 upstream prematurely closed connection while reading response header from upstream, client: 127.0.0.1, server: v2.localhost, request: "GET / HTTP/1.1", upstream: "http://unix:/run/fastcgi/site-v2.main.sock:/", host: "v2.localhost:8000"

Assim, nenhum trabalhador responde ao pedido. netstat -x não exibe o socket, mas parece que está em uso, porque se eu tentar iniciar meu script start duas vezes ele diz spawn-fcgi: socket is already in use, can't spawn .

Uma última coisa: se eu iniciar meu script de início e não tentar solicitar uma página, os processos do multiwatch e os trabalhadores serão finalizados corretamente com um kill para o multiwatch. Mas se eu pedir uma página, o multiwatch deveria enviar a resposta e todos seus filhos funcionarem. Eu tenho que kill -9 todos eles.

Os pontos de entrada do site são assim:

require 'fcgi'

FCGI.each do |req|
    process req
end

Meu script de inicialização:

USER=www-site-v2
GROUP=www-site-v2

SOCK_MODE=0660

NB_WORKERS_MAIN=4
NB_WORKERS_AJAX=4

MULTIWATCH_BIN=/usr/bin/multiwatch

APP_MAIN=/var/www/site-v2/www/main.rb
APP_AJAX=/var/www/site-v2/www/ajax.rb

PID_MAIN=/run/fastcgi/site-v2.main.pid
PID_AJAX=/run/fastcgi/site-v2.ajax.pid

SOCK_MAIN=/run/fastcgi/site-v2.main.sock
SOCK_AJAX=/run/fastcgi/site-v2.ajax.sock

SPAWN_BIN=/usr/bin/spawn-fcgi
SPAWN_ARGS="-u $USER -g $GROUP -M $SOCK_MODE -d /var/www/site-v2/www"
SPAWN_ARGS_MAIN="-s $SOCK_MAIN -P $PID_MAIN"
SPAWN_ARGS_AJAX="-s $SOCK_AJAX -P $PID_AJAX"

case "$1" in
    start)
        test \! -d /run/fastcgi && mkdir /run/fastcgi

        $SPAWN_BIN $SPAWN_ARGS $SPAWN_ARGS_MAIN -- $MULTIWATCH_BIN -f $NB_WORKERS_MAIN -- $APP_MAIN && \
        $SPAWN_BIN $SPAWN_ARGS $SPAWN_ARGS_AJAX -- $MULTIWATCH_BIN -f $NB_WORKERS_AJAX -- $APP_AJAX
        ;;
    stop)
        test -f $PID_MAIN && kill 'cat $PID_MAIN'
        test -f $PID_AJAX && kill 'cat $PID_AJAX'
esac

Meu arquivo de configuração do nginx:

server {
    listen 8000;
    server_name v2.localhost;

    location ^~ /theme/      { root /var/www/site-v2/www/static; }
    location ^~ /javascript/ { root /var/www/site-v2/www/static; }
    location ^~ /avatars/    { root /var/www/site-v2/www/static; }

    location / {
        include fastcgi_params;
        proxy_redirect off;
        proxy_pass http://unix:/run/fastcgi/site-v2.main.sock:;
    }

    location /ajax/ {
        include fastcgi_params;
        proxy_redirect off;
        proxy_pass http://unix:/run/fastcgi/site-v2.ajax.sock:;
    }
}
    
por Pikrass 04.04.2013 / 00:19

1 resposta

0

Ok, eu sou burro. Por alguma razão, usei proxy_pass em vez de fastcgi_pass no meu arquivo de configuração nginx. Então nginx usou o protocolo errado, os trabalhadores foram "wtf?" e pendurado.

Funciona como um encanto agora.

server {
    listen 8000;
    server_name v2.localhost;

    location ^~ /theme/      { root /var/www/site-v2/www/static; }
    location ^~ /javascript/ { root /var/www/site-v2/www/static; }
    location ^~ /avatars/    { root /var/www/site-v2/www/static; }

    location / {
        include fastcgi_params;
        fastcgi_pass unix:/run/fastcgi/site-v2.main.sock;
    }

    location /ajax/ {
        include fastcgi_params;
        fastcgi_pass unix:/run/fastcgi/site-v2.ajax.sock;
    }
}
    
por 07.04.2013 / 02:11