Krystian Cybulski Asked: 2009-07-16 16:40:10 +0800 CST2009-07-16 16:40:10 +0800 CST 2009-07-16 16:40:10 +0800 CST logrotate 用日期重命名文件 772 现在,logrotate 将旧的日志文件重命名为 access.log.1.gz、access.log.2.gz 等。我更喜欢将它们命名为 access.log.20090714.gz、access.log.20090715.gz、等 - 每天一个。 我找不到为旧日志文件指定文件名模式的任何选项。你知道怎么做吗? 顺便说一句,这是用于旋转 lighttpd 日志文件,如果这很重要的话。 lighttpd logrotate 3 个回答 Voted Best Answer Juliano 2009-07-16T17:07:51+08:002009-07-16T17:07:51+08:00 在/etc/logrotate.confor/etc/logrotate.d/lighttpd或其他任何地方的适当文件中,添加dateext到要应用日期后缀的节。 来自logrotate 手册页的更多信息: 日期文本 归档旧版本的日志文件,添加一个每日扩展名,如 YYYYMMDD,而不是简单地添加一个数字。 Cos 2009-07-16T16:48:47+08:002009-07-16T16:48:47+08:00 使用 cronolog - 它首先会使用正确的文件名写入日志文件(例如,我通常让我的网络服务器将日志文件写入为 YYYY/MM/DD/access 或 YYYY/MM/DD/error 等)。有关使用 lighttpd 配置 cronolog 的更多详细信息,请参见此处:http ://redmine.lighttpd.net/projects/1/wiki/MigratingFromApache (虽然该页面提到 server.errorlog 无法通过 cronolog 运行,但似乎有一个错误报告已标记为“已修复” - 不幸的是我一次不能发布多个 URL,因为我是服务器故障的“新”用户...) theotherreceive 2009-07-16T16:47:01+08:002009-07-16T16:47:01+08:00 我不认为 lighttpd 或 logrotate 可以自己做到这一点。我看到了两个选项来实现这一点: 在 logrotate 之后直接编写自己的脚本,就像在它的 cronjob 结束时一样。就像是: if [ -f /var/log/lighttpd/access.log.1.gz ]; then` mv /var/log/lighttpd/access.log.1.gz /var/log/lighttpd/access.log.$date.gz fi 或者,syslog-ng 可以按日期构建日志文件,而 lighttpd 可以将日志发送到 syslog,而不是自己编写日志。 # syslog-ng.conf destination df_lighttpd { file("/var/log/lighttpd/$YEAR$MONTH$DAY.log"); }; filter f_lighttpd { program("lighttpd"); }; log { source(s_all); filter(f_lighttpd); destination(df_lighttpd); }; 并在 lighttpd conf 中设置accesslog.use-syslog& 。server.errorlog-use-syslog 编辑: Cronolog 比我的任何一个建议更简单和/或,如果它适合你,我会接受。
在
/etc/logrotate.conf
or/etc/logrotate.d/lighttpd
或其他任何地方的适当文件中,添加dateext
到要应用日期后缀的节。来自logrotate 手册页的更多信息:
使用 cronolog - 它首先会使用正确的文件名写入日志文件(例如,我通常让我的网络服务器将日志文件写入为 YYYY/MM/DD/access 或 YYYY/MM/DD/error 等)。有关使用 lighttpd 配置 cronolog 的更多详细信息,请参见此处:http ://redmine.lighttpd.net/projects/1/wiki/MigratingFromApache
(虽然该页面提到 server.errorlog 无法通过 cronolog 运行,但似乎有一个错误报告已标记为“已修复” - 不幸的是我一次不能发布多个 URL,因为我是服务器故障的“新”用户...)
我不认为 lighttpd 或 logrotate 可以自己做到这一点。我看到了两个选项来实现这一点:
在 logrotate 之后直接编写自己的脚本,就像在它的 cronjob 结束时一样。就像是:
或者,syslog-ng 可以按日期构建日志文件,而 lighttpd 可以将日志发送到 syslog,而不是自己编写日志。
并在 lighttpd conf 中设置
accesslog.use-syslog
& 。server.errorlog-use-syslog
编辑: Cronolog 比我的任何一个建议更简单和/或,如果它适合你,我会接受。