logrotate 日志轮转

logrotate -f /etc/logrotate.conf

 

手动执行:

logrotate 可以直接执行,后面跟配置文件就可以了,如:/usr/sbin/logrotate -f /etc/logrotate.d/nginx

参数:

-v 显示指令执行过程

-d Debug模式(模拟执行),详细显示指令执行过程,便于排错或了解程序执行的情况。

-f 强制执行

-s <状态文件> 使用指定的状态文件

 

主要参数:

默认配置文件 /etc/logrotate.conf:

daily指定转储周期为每天

weekly指定转储周期为每周

monthly指定转储周期为每月

dateext 切换后的日志文件会附加上一个短横线和YYYYMMDD格式的日期,没有这个配置项会附加一个小数点加一个数字序号.

dateformat 配合dateext使用可以为切割后的日志加上YYYYMMDD格式的日期,如dateformat -%Y%m%d

compress通过gzip 压缩转储以后的日志

nocompress不需要压缩时,用这个参数

copytruncate先把日志内容复制到旧日志文件后才清除日志文件内容,可以保证日志记录的连续性

nocopytruncate备份日志文件但是不截断

create mode owner group转储文件,使用指定的文件模式创建新的日志文件

nocreate不建立新的日志文件

delaycompress和 compress 一起使用时,转储的日志文件到下一次转储时才压缩

nodelaycompress覆盖 delaycompress 选项,转储同时压缩。

errors address专储时的错误信息发送到指定的Email 地址

ifempty即使是空文件也转储,这个是 logrotate 的缺省选项。

notifempty如果是空文件的话,不转储

mail address把转储的日志文件发送到指定的E-mail 地址

nomail转储时不发送日志文件

olddir directory转储后的日志文件放入指定的目录,必须和当前日志文件在同一个文件系统

noolddir转储后的日志文件和当前日志文件放在同一个目录下

rotate count指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份

tabootext [+] list让logrotate 不转储指定扩展名的文件,缺省的扩展名是:.rpm-orig, .rpmsave, v, 和 ~

size size当日志文件到达指定的大小时才转储,Size 可以指定 bytes (缺省)以及KB (sizek)或者MB (sizem).

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

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

 

案例一:

vi /etc/logrotate.d/nginx

/var/log/nginx/*.log

{

daily#指定转储周期为每天

missingok #跳过错误日志文件

rotate 5#保留5个文件

compress#通过gzip 压缩转储以后的日志

delaycompress#和 compress 一起使用时,转储的日志文件到下一次转储时才压缩

ifempty

create 0640 www-data adm

sharedscripts

postrotate

#kill -USR1 `cat /var/run/nginx.pid不是中止Nginx的进程,而是传递给它信号重新生成日志,如果nginx没启动不做操作

[ ! -f /var/run/nginx.pid ] || kill -USR1 `cat /var/run/nginx.pid`

endscript

}

 

案例二:

/var/log/debug.log
{
        daily   ;每天转储
        rotate 30  ;保留30个备份
        compress   ;压缩转储的备份文件
        copytruncate ;备份当前日志并截断
        nocreate      ;不创建新的日志文件
        delaycompress  ;转储的日志文件到下一次转储时才压缩
        notifempty  ;日志为空不转储
        dateext   ; 为日志文件打上日期标签
}

 

案例三:

/var/log/messages
{
missingok
notifempty
copytruncate
size 1M
daily
rotate 10
create 0600 root root
dateformat -%Y%m%d.%s
sharedscripts
postrotate
/bin/kill -HUP `cat /var/run/syslogd.pid 2> /dev/null` 2> /dev/null || true
endscript
}

 

 

 

 

 

 

此条目发表在linux分类目录,贴了, 标签。将固定链接加入收藏夹。