jay*_*abs 5 linux ubuntu logging logrotate
我error_log = /var/log/php5-fpm.log在/etc/php5/fpm/php-fpm.conf运行nginx和php5-fpm的ubuntu 12.04上启用了under .
但是我注意到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
}
Run Code Online (Sandbox Code Playgroud)
这是配置的链接.据我所知,我只需要创建一个名为php5-fpmunder 的文件/etc/logrotate.d/,所以它看起来/etc/logrotate.d/php5-fpm和上面的代码一样.
我还从此链接中找到了另一个示例,其中包含以下代码:
/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
}
Run Code Online (Sandbox Code Playgroud)
由于我是logrotate配置的新手,我想确保我要做的是正确的.
那么,这两种配置中的哪一种是正确的?第一个还是第二个?我只创建一个文件/etc/logrotate.d/php5-fpm并将代码放在那里是否正确?
对不起,如果这是一个新手问题,我就找不到如何做到这一点的完整说明.
只是为了通过谷歌来澄清其他人:
1)
invoke-rc.d php5-fpm reopen-logs > /dev/null
Run Code Online (Sandbox Code Playgroud)
这是您的发行版必须支持的内容.选项"重新打开,日志"并没有配备由PHP源代码包提供的默认初始化脚本.所以你可能无法使用它.
2)
[ ! -f /var/run/php5-fpm.pid ] || kill -USR1 `cat /var/run/php5-fpm.pid`
Run Code Online (Sandbox Code Playgroud)
这是正确的选项,也正式得到PHP-FPM的支持,请参阅:https: //github.com/php/php-src/blob/b7a7b1a624c97945c0aaa49d46ae996fc0bdb6bc/sapi/fpm/fpm/fpm_events.c#L94
你可以从源代码中看到这个"信号"是额外用于对数转换的,应该优于"USR2",它只能用于重新加载配置.
| 归档时间: |
|
| 查看次数: |
4210 次 |
| 最近记录: |