2017-02-16 5 views
1

Я столкнулся с странным поведением. Я запускаю NGINX с PHP-FPM.Журнал ошибок NGINX отключается, когда включен журнал ошибок PHP

Когда я включаю журнал PHP ошибок в php.ini:

error_log = /var/www/logs/php-scripts.error.log 
log_errors = on 

журнал ошибок записывается, как и ожидалось:

... 
[15-Feb-2017 19:35:28 Etc/UTC] PHP Parse error: syntax error, unexpected end of file, expecting ',' or ';' in /var/www/html/index.php on line 7 

Однако, в то же время, журнал ошибок, сконфигурированной в моей NGINX vhost не записывается вообще (это фрагмент конфигурации NGINX):

server { 
    listen 80; 
    server_name vhost.com; 

    access_log /var/log/nginx/access.log main; 
    error_log /var/log/nginx/error.log; <- this is always empty 
} 

Теперь, к моему удивлению, когда я отключить журнал ошибок в php.ini:

; error_log = /var/www/logs/php-scripts.error.log <-- commented out 
log_errors = on 

журнал ошибок NGINX записывается в:

... 
2017/02/16 12:01:44 [error] 13#13: *27 FastCGI sent in stderr: "PHP message: PHP Parse error: syntax error, unexpected end of file, expecting ',' or ';' in /var/www/html/index.php on line 7" while reading response header from upstream, client: 172.19.0.2, server: domain.com, request: "GET/HTTP/1.1", upstream: "fastcgi://172.19.0.3:9000", host: "domain.com:8080" 

Я не понимаю такое поведение вообще. Каков источник этой помехи между двумя системами регистрации? Почему я не могу включить журнал ошибок в php.ini и в то же время записывать журнал ошибок NGINX? На данный момент это то или другое. Можно ли решить эту проблему?

ответ

2

PHP сообщает об ошибках в файл журнала, syslog (3) или stderr, в зависимости от того, установлен ли и как установлен error_log. См. this document.

nginx будет регистрировать сообщения, которые он получает по потоку Stderr FastCGI.

Итак, это не странное поведение.

+0

Если я правильно понимаю, я хочу, чтобы при перенаправлении PHP-ошибок в файл ошибки не испускались в stderr, поэтому nginx не будет считывать поток, и его журнал ошибок будет пустым. – luqo33

+0

Да. Правильно. –