У нас есть два веб-сервера с nginx + php-fpm (10.0.0.10 и 10.0.0.20), которые балансируются по нагрузке за другим сервером nginx (просто nginx), когда мы пытаемся просмотреть, мы получаем ошибку файл не найден, с перечисленными журналами ошибок внизу.
Балансировщик нагрузки (10.0.0.1)
nginx.conf
upstream test_rack {
server 10.0.0.10:80;
server 10.0.0.20:80;
}
server {
location / {
proxy_pass http://test_rack;
}
}}
Сервер восходящей передачи (10.0.0.20)
subdomains.conf
server {
listen 80;
server_name ~^(?<sub>.+)\.example\.com$;
root /data/vhost/$sub.example.com/htdocs;
location / {
try_files $uri /index.php;
}
location ~ \.php$ {
fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}}
Ошибка на веб-сервере (10.0.0.10 и 10.0.0.20)
*1 FastCGI sent in stderr: "Primary script unknown" while reading response header from upstream, client: 10.0.0.1, server: ~^(?<sub>.+)\.example\.com$, request: "GET / HTTP/1.0", upstream: "fastcgi://unix:/var/run/php5-fpm.sock:", host: "test_rack"
Решения пробовали:
fastcgi_param SCRIPT_FILENAME /data/vhost/$sub.example.com/htdocs/$fastcgi_script_name;
Похоже, что по какой-то причине ваше регулярное выражение не совпадает, поэтому #sub не инициализируется, и это приводит к ошибке. Попробуйте сначала указать server_name без регулярного выражения, чтобы увидеть, что не так.