O php-fpm não está em execução. Apenas comece.
Eu tenho um aplicativo rails (vamos chamá-lo myapp) rodando em www.myapp.com. Eu quero adicionar um blog wordpress em www.myapp.com/blog. O servidor web do aplicativo rails é fino (veja o bloco upstream). O wordpress é executado com o php-fastcgi.
O aplicativo rails funciona bem. Meu problema é o seguinte: em /home/myapp/myapp/log/error.log error
eu recebo:
2013/06/24 10:19:40 [error] 26066#0: *4 connect() failed (111: Connection refused) while connecti\
ng to upstream, client: xx.xx.138.20, server: www.myapp.com, request: "GET /blog/ HTTP/1.1", \
upstream: "fastcgi://127.0.0.1:9000", host: "www.myapp.com"
Aqui está o arquivo conf nginx:
upstream myapp {
server unix:/tmp/thin_myapp.0.sock;
server unix:/tmp/thin_myapp.1.sock;
server unix:/tmp/thin_myapp2.sock;
}
server {
listen 80;
server_name www.myapp.com;
client_max_body_size 20M;
access_log /home/myapp/myapp/log/access.log;
error_log /home/myapp/myapp/log/error.log error;
root /home/myapp/myapp/public;
index index.html;
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host;
proxy_redirect off;
# Index HTML Files
if (-f $document_root/cache/$uri/index.html) {
rewrite (.*) /cache/$1/index.html break;
}
if (!-f $request_filename) {
proxy_pass http://myapp;
break;
}
# try_files /system/maintenance.html $uri $uri/index.html $uri.html @ruby;
}
location /blog/ {
root /var/www/wordpress;
fastcgi_index index.php;
if (!-e $request_filename) {
rewrite ^(.*)$ /blog/index.php?q=$1 last;
}
include /etc/nginx/fastcgi_params;
fastcgi_param SCRIPT_FILENAME /var/www/wordpress$fastcgi_script_name;
fastcgi_pass localhost:9000; # port to FastCGI
}
}
Alguma idéia de por que isso não funciona? Como posso ter certeza de que o php-factcgi está configurado corretamente?
Editar: Eu não posso testar se o fastcgi está rodando com o telnet:
$> telnet 127.0.0.1 9000
Trying 127.0.0.1...
telnet: Unable to connect to remote host: Connection refused
E não é.
A raiz do problema era que o php-fpm não estava rodando (como apontou @Michael)
Eu também alterei o bloco de localização porque os recursos não foram exibidos com a configuração original:
location ^~ /blog {
root /var/www/wordpress;
index index.php index.html index.htm;
try_files $uri $uri/ /blog/index.php?$args;
location ~ \.php$ {
include /etc/nginx/fastcgi_params;
#if ($uri !~ "^/images/") {
# fastcgi_pass unix:/var/run/php-fastcgi/php-fastcgi.socket;
#}
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /var/www/wordpress$fastcgi_script_name;
fastcgi_pass localhost:9000;
}
}