我在运行nginx和php5-fpm的ubuntu 12.04上的error_log = /var/log/php5-fpm.log
下启用了/etc/php5/fpm/php-fpm.conf
。
但是我注意到php5-fpm.log没有logrotate。我试图理解我从互联网上找到的一些配置,但我不愿意在我的生产服务器上测试它。
以下是我找到的一些配置:
/var/log/php5-fpm.log {
rotate 12
weekly
missingok
notifempty
compress
delaycompress
postrotate
invoke-rc.d php5-fpm reopen-logs > /dev/null
endscript
}
这是配置的link。据我所知,我只需要在php5-fpm
下创建一个名为/etc/logrotate.d/
的文件,因此它看起来像/etc/logrotate.d/php5-fpm
并使用上面的代码。
我还从此link找到了另一个示例,其中包含以下代码:
/var/log/php5-fpm.log {
daily
missingok
rotate 52
compress
delaycompress
notifempty
create 640 root adm
sharedscripts
postrotate
[ ! -f /var/run/php5-fpm.pid ] || kill -USR1 `cat /var/run/php5-fpm.pid`
endscript
}
由于我是logrotate配置的新手,我想确保我要做的是正确的。
那么,这两种配置中的哪一种是正确的?第一个还是第二个?我只在/etc/logrotate.d/php5-fpm
创建一个文件并将代码放在那里是否正确?
很抱歉,如果这是一个新手问题,我无法找到有关如何执行此操作的完整说明。
答案 0 :(得分:6)
为了澄清其他通过Google传播的内容:
1)
invoke-rc.d php5-fpm reopen-logs > /dev/null
这是您的发行版必须支持的内容。 “reopen-logs”选项不附带PHP源包提供的默认初始化脚本。所以你可能无法使用它。
2)
[ ! -f /var/run/php5-fpm.pid ] || kill -USR1 `cat /var/run/php5-fpm.pid`
这是正确的选项,并且正式得到PHP-FPM的支持,请参阅: https://github.com/php/php-src/blob/b7a7b1a624c97945c0aaa49d46ae996fc0bdb6bc/sapi/fpm/fpm/fpm_events.c#L94
你可以从源代码中看到这个“信号”是额外用于logrotating的,并且应该优于“USR2”,它只能用于重新加载配置。