这篇文章上次修改于 3408 天前,可能其部分内容已经发生变化,如有疑问可询问作者。

mysql日志不支持按天切割,时间久了导致文件太大,无法打开查看。所以我们可以按天来切割mysql的慢日志。

1.打开/创建规则文件

cd /etc/logrotate.d/
vi mysqld

2.编写规则

/data/bin-log/slow_queries {
        create  777 mysql mysql
        dateext
        notifempty
        daily
        maxage 60
        rotate 30
        missingok
        nocompress
        #olddir /data/httplogs/old_log
        postrotate
        # just if mysqld is really running
        if test -x /usr/local/mysql/bin/mysqladmin && /usr/local/mysql/bin/mysqladmin ping -uroot -pYourPassword -S /tmp/mysql.sock &>/dev/null
        then
           /usr/local/mysql/bin/mysqladmin flush-logs -uroot -pYourPassword -S /tmp/mysql.sock
        fi
    endscript
}

3.保存规则文件

4.测试:

logrotate -d -f /etc/logrotate.d/mysqld

 

5. logrotate基本配置参数说明:

  • 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 转储后的日志文件和当前日志文件放在同一个目录下
  • prerotate/endscript 在转储以前需要执行的命令可以放入这个对,这两个关键字必须单独成行
  • postrotate/endscript 在转储以后需要执行的命令可以放入这个对,这两个关键字必须单独成行
  • daily 指定转储周期为每天
  • weekly 指定转储周期为每周
  • monthly 指定转储周期为每月
  • rotate count 指定日志文件删除之前转储的次数,0 指没有备份,5 指保留5 个备份
  • tabootext [+] list 让logrotate 不转储指定扩展名的文件,缺省的扩展名是:.rpm-orig, .rpmsave, v, 和 ~
  • size size 当日志文件到达指定的大小时才转储,bytes(缺省)及KB(sizek)或MB(sizem)