Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1750658
  • 博文数量: 117
  • 博客积分: 2559
  • 博客等级: 少校
  • 技术积分: 4385
  • 用 户 组: 普通用户
  • 注册时间: 2010-08-13 20:08
个人简介

作为初学者,要想取得进步,成为高手,首先应该了解自己的不足之处.

文章分类

全部博文(117)

文章存档

2014年(1)

2013年(25)

2012年(13)

2011年(77)

2010年(1)

分类: Mysql/postgreSQL

2013-05-15 14:15:34

原因:面对累计长时间的慢查询日志,检索起来非常不方便.

目的:按天分割慢查询日志.

方法:利用logrotate工具

实现

logrotate介绍

logrotate是管理日志文件的工具,在CentOS系统中,命令的位置在/usr/sbin/logrotate,常用的操作如:
  -d, --debug               Don't do anything, just test (implies -v)
  -f, --force               Force file rotation
注意:带有d参数,并不会产生新日志.
logrotate一般每天由cron运行一次.标准的配置文件是/etc/logrotate.conf,而/etc/logrotate.d目录也是保存配置文件的位置.

logrotate常见选项:
选项 含义
compress 压缩日志文件的所有非当前版本
copy 复制当前的日志文件,忽略create参数
copytruncate 复制当前的日志文件,并置空当前文件
daily 每天轮日志文件i
dateext 轮换的日志后缀为-YYYYMMDD格式
delaycompress 压缩除了当前和最近之外的所有其他版本
missingok 如果日志不存在,不会报错
notifempty 如果日志为空,则不轮换
rotate n 在轮换方案中包含n个版本的日志
size=logsize 如果日志文件大于logsize才轮换

轮换MySQL日志的配置文件


  1. /var/log/mysql/slow_3306.log 
  2. /var/log/mysql/slow_3307.log {
  3. # compress
  4. copytruncate
  5. # create 644 mysql mysql
  6. daily
  7. dateext
  8. delaycompress
  9. missingok
  10. notifempty
  11. rotate 7
  12. # size 1M
  13. }

可以切换两个配置文件.或者用*.log,切换目录下所有的.
调试命令

/usr/sbin/logrotate -d /etc/logrotate.d/mysql-slow
/usr/sbin/logrotate -f /etc/logrotate.d/mysql-slow

附:

利用copytruncate选项,没有必要使用postrotate选项,在轮换日志后,给MySQL发送flush logs;命令.

阅读(7132) | 评论(0) | 转发(4) |
给主人留下些什么吧!~~