|
Много уебмастъри се сблъскват с 500 502 проблема след преминаване към nginx+php-fpm. Когато nginx получи горния код за грешка, може да се установи, че има някакъв проблем с php-парсирането на php в бекенд, като например грешка при изпълнение или таймаут на изпълнение. php-fpm.conf има параметър request_slowlog_timeout описан по този начин - ; The timeout for serving a single request after which a PHP backtrace will be
- ; dumped to the 'slowlog' file. A value of '0s' means 'off'.
- ; Available units: s(econds)(default), m(inutes), h(ours), or d(ays)
- ; Default Value: 0
- ;request_slowlog_timeout = 0
Копирай кодКогато request_slowlog_timeout е зададен на конкретна секунда request_slowlog_timeout =5, това означава, че ако скриптът се изпълнява повече от 5 секунди, той ще бъде записан в бавния лог файл
request_slowlog_timeout =0 означава, че бавният лог изход е изключен. Местоположението на бавния лог файл по подразбиране е в папката log в инсталационната директория на php и можеш да го зададеш, като промениш параметъра slowlog = log/$pool.log.slow. Пример за бавен лог PHP-FPM – бавният лог записва номера на процеса, името на скрипта, конкретния файл, кой ред код, коя функция е твърде дълга за изпълнение. - [21-Nov-2013 14:30:38] [pool www] pid 11877
- script_filename = /usr/local/lnmp/nginx/html/www.quancha.cn/www/fyzb.php
- [0xb70fb88c] file_get_contents() /usr/local/lnmp/nginx/html/www.quancha.cn/www/fyzb.php:2
- [21-Nov-2013 14:15:23] ERROR: [pool www] 'slowlog' must be specified for use with 'request_slowlog_timeout'
Копирай кодrequest_slowlog_timeout и slowlog трябва да се настроят едновременно, а slowlog трябва да се включи едновременно с включването на request_slowlog_timeout - [21-Nov-2013 14:16:27] ERROR: Unable to create or open slowlog(/usr/local/lnmp/php/log/www.log.slow): No such file or directory (2)
Копирай кодБавните лог пътища трябва да се създават ръчно
Конкретни стъпки за активиране на php-fpm бавно логване: - cd /usr/local/lnmp/php
- vi etc/php-fpm.conf
- 去掉request_slowlog_timeout 、slowlog的前缀分号';',设置request_slowlog_timeout =5;
- :wq
- 保存退出
- 创建慢日志目录
- mkdir log
- 重启php-fpm
- kill -INT `cat var/run/php-fpm.pid
- sbin/php-fpm
Копирай код
|