Właśnie zainstalowałem nginx i php5-fpm i chcę go przetestować na porcie 82. Więc dzwonię pod adres http://mysite.com:82/test555.php i nic nie widzę. Tylko biały ekran. Bez błędów, bez ostrzeżeń, nic nie widzę :) Istnieje dziennik błędów nginx i dziennik błędów php5-fpm - ale ... Nie ma żadnych błędów. Nie rozumiem, co jest nie tak. Proszę, pomóż mi to znaleźć.
root@localhost:# echo "<?php phpinfo(); ?>" > /home/www/public_html/test555.php
root@localhost:# chmod 755 /home/www/public_html/test555.php
root@localhost:# cat /etc/nginx/sites-available/default
server {
listen 82;
root /home/www/public_html;
index index.php index.html;
server_name mysite.com;
access_log /var/log/nginx/nginx-access.com.log;
error_log /var/log/nginx/nginx-errors.com.log;
location ~ \.php$ {
fastcgi_pass unix:/var/run/php5-fpm.sock;
# fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param QUERY_STRING $query_string;
fastcgi_param REMOTE_ADDR $remote_addr;
}
}
root@localhost:# /etc/init.d/nginx status
* nginx is running
root@localhost:# /etc/init.d/php5-fpm status
* php5-fpm is running
root@localhost:# ls -la /var/run/php5-fpm.sock
srw-rw-rw- 1 root root 0 Feb 3 01:14 /var/run/php5-fpm.sock
root@localhost:# cat /var/log/php5-fpm.log
....
[03-Feb-2014 01:14:52] NOTICE: configuration file /etc/php5/fpm/php-fpm.conf test is successful
[03-Feb-2014 01:14:52] NOTICE: fpm is running, pid 19080
[03-Feb-2014 01:14:52] NOTICE: ready to handle connections
root@localhost:# cat /var/log/nginx/nginx-access.com.log
...ip... - - [03/Feb/2014:01:29:44 +0000] "GET /test555.php HTTP/1.1" 200 5 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.8; rv:26.0) Gecko/20100101 Firefox/26.0"
root@localhost:# cat /var/log/nginx/nginx-errors.com.log
root@localhost:#
Co mogę zrobić, aby dowiedzieć się, co się dzieje? Widzę, że powinno działać dobrze. Skrypt PHP zwraca mi kod = 200, ale nie widzę danych wyjściowych. Nigdy nie został wywołany, ponieważ próbowałem tam dodać file_put_contents i naprawdę nigdy nie został wywołany przez nginx.
Używam Ubuntu 12.04 w pełni zaktualizowany dzisiaj.
/var/log/nginx/nginx-errors.com.log
?Odpowiedzi:
To SO Q&A brzmi, jakby to był twój problem, zatytułowany: nginx pokazujący puste strony PHP .
Twoja
location
zwrotka powinna wyglądać podobnie do tego:Musisz zwrócić szczególną uwagę na ścieżkę do skryptu, do którego się odwołujesz
fastcgi_param
.Bibliografia
źródło
Może to być przydatne dla innych osób borykających się z tym problemem,
Możesz również dodać do pliku conf nginx
fastcgi_params
następujący wiersz, więc nie musisz określać ścieżki do zmiennejSCRIPT_FILENAME
Jest to bardzo przydatne szczególnie, gdy masz wiele wirtualnych hostów.
źródło