Linux下log日志轮转

服务器上的日志包括系统日志和服务日志每天都会产生n多log,好多人会自己写脚本来进行日志的切割、压缩等,而忽略了系统自带的服务--logrotate

简介

logrotate是个十分有用的工具,它可以自动对日志进行截断(或轮循)、压缩以及删除旧的日志文件。它是基于CRON来运行的,其脚本是「/etc/cron.daily/logrotate」。主流Linux发行版上都默认安装有logrotate包,这也是我选择用他的主要原因。

使用

实际运行时,Logrotate会调用配置文件「/etc/logrotate.conf」:

也可以在「/etc/logrotate.d」目录里放置自己的配置文件,用来覆盖Logrotate的缺省值。

下面是一个切割rabbitmq日志的例子:

/var/log/rabbitmq/*.log {
        weekly
        missingok
        rotate 20
        compress
        delaycompress
        notifempty
        dateext
        copytruncat
        sharedscripts     
        postrotate
            /etc/init.d/rabbitmq-server rotate-logs > /dev/null
        endscript

logrotate参数说明:

daily — 每日旋转日志文件。
weekly — 每周旋转日志文件。
monthly — 每月旋转日志文件。

compress — 用gzip压缩旋转的日志文件。

size size — 在日志文件达到一定大小时开始旋转。大小是以bytes (默认), kilobytes (sizek)或megabytes (sizem)计算。

nocompress — 在不需要压缩旋转日志文件的情况下使用。

delaycompress — 在使用压缩选择时,旋转文件不会在下一个循环开始时被压缩。

copytruncate — 用于还在打开中的日志文件,把当前日志备份并截。复制当前的日志文件,并置空当前文件。

nocopytruncate — 把日志文件复制进备份,但该开放文件不会被裁剪。

dateext - 用时间格式表示日志,轮换的日志后缀为-YYYYMMDD格式

rotate count — 在删除前旋转文件的特定次数。如果计数为零,就意味着没有副本保留。而5则意味着保留5个副本。

create mode owner group — 旋转日志文件并创建允许特定组合用户的新文件。缺省是使用与原始文件一样的模式,组合用户。

missiongok - 如果文件找不到的话不会报错,直接跳过

nocreate — 可以防止产生新日志文件。

nodelaycompress –    日志文件会在循环过程中被压缩。

errors address — 将logrotate错误邮件发送到某个地址。

ifempty — 即使在空文件时也要旋转。这是Logrotate的缺省项。

notifempty — 空文件不旋转。

mail address — 这个邮件日志文件是循环到一个地址,因此能有效从系统中清楚。

nomail - 在邮件日志循环时,副本不邮寄。

olddir directory — 这个选项会将循环日志文件保持在特定目录。该目录必需与现有日志文件在同一文件系统。

noolddir — 循环的日志文件与现有文件处于相同目录。

prerotate/endscript - 在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行

postrotate/endscript - 在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行

其他参数可自行通过man logrotate查看帮助。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/9a36b0dc759b3dbdbcb6d1f01dfa0591.html