linux - 怎么用logrotate管理分割nginx日志,并指定文件名格式

 hja2045905 发布于 2022-11-06 09:51

我自己写了一个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
}
1 个回答
  • 是的,你用 *.log 就是匹配所有 .log 文件。你现在只要 access.log 就直接 /var/log/nginx/access.log 即可

    2022-11-12 01:48 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有