linux - 怎么用logrotate管理分割nginx日志,并指定文件名格式
PHP中文网
PHP中文网 2017-04-17 11:17:38
[Linux讨论组]

我自己写了一个logrotate的管理脚本,来分割nginx的日志,日志的名字希望是access20130423.log,也就是说是access%Y%m%d.log,本来默认不设置的话,会生成access%Y%m%d,可单位那个脑残的日志分析系统,必须要.log后缀。多脑残的系统连后缀名都不能自定义,卧槽,额跑题了。。。

下边的脚本是我写的,可是有问题,最终会生成这样一些文件

root@debian:/var/log/nginx# ls -lh
total 40M
-rw-r----- 1 www-data www-data 6.0M Apr 24 09:48 access.log
-rw-r----- 1 www-data www-data    0 Apr 24 06:26 access20130423.log
-rw-r--r-- 1 www-data www-data 1.6K Apr 23 11:10 access2013042320130424.log
-rw-r----- 1 www-data www-data  34M Apr 24 06:26 access20130424.log
-rw-r----- 1 www-data www-data  21K Apr 24 09:40 error.log
-rw-r--r-- 1 www-data www-data 138K Apr 24 06:24 error20130424.log

第三个文件是怎么回事,为什么会生成这样一个文件。。。。。

是不是 /var/log/nginx/*.log这里 应该明确的指定access.log?

/var/log/nginx/*.log {
 daily
 dateext
 dateformat %Y%m%d
 extension .log
 create
 rotate 60
 #compress
 #delaycompress
 notifempty
 create 0640 www-data www-data
 sharedscripts
 prerotate
     if [ -d /etc/logrotate.d/httpd-prerotate ]; then \
         run-parts /etc/logrotate.d/httpd-prerotate; \
     fi \
 endscript
 postrotate
     [ ! -f /var/run/nginx.pid ] || kill -USR1 `cat /var/run/nginx.pid`
 endscript
}
PHP中文网
PHP中文网

认证0级讲师

全部回复(1)
伊谢尔伦

是的,你用 *.log 就是匹配所有 .log 文件。你现在只要 access.log 就直接 /var/log/nginx/access.log 即可

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号