Я запускаю приложение PHP на nginx с HHVM в качестве основного и PHP-FPM в качестве резервного
Это моя конфигурация nginx относительно обработки php
location ~ \.(hh|php)$ {
fastcgi_intercept_errors on;
error_page 500 501 502 503 = @fallback;
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_keep_conn on;
include fastcgi_params;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param SERVER_NAME $host;
fastcgi_pass 127.0.0.1:9000;
}
location @fallback {
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
include fastcgi_params;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param SERVER_NAME $host;
fastcgi_pass unix:/var/run/php5-fpm.sock;
}
Чтобы проверить конфигурацию, я остановил службу hhvm. Обычно она передает запрос в PHP-FPM и должна возвращать 200, но я получаю ошибку 502 следующим образом:
12296#0: *17 connect() failed (111: Connection refused) while connecting to upstream, client: 172.31.34.235, server: stylep3.com, request: "GET / HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000", host:localhost
Я здесь что-то не так делаю
Я обнаружил, что hhvm включает hhvm.conf в файл vhost по умолчанию для nginx.
Это обработка запроса и отправка ошибки.
Я изменил конфигурацию на
upstream php_backend {
server 127.0.0.1:9000;
server unix:/var/run/php5-fpm.sock backup;
}
server {
#
# other conf...
#
location ~ \.(hh|php)$ {
fastcgi_intercept_errors on;
try_files $uri =404;
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_keep_conn on;
include fastcgi_params;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param SERVER_NAME $host;
fastcgi_pass php_backend;
}
}
и удалил строку
include hhvm.conf
из файла vhost.
Это решило проблему!