背景:
对于MySQL的日志,如果不做处理的话,时间长了会很大,不利于分析问题。比如说错误日志或者慢日志,经过半年一年可能已经很大了,你要想查看内容会很慢,搞不好把系统都可能跑挂。或者当你监控报警的时候提示磁盘空间不足,你登陆服务器发现都是log占用,我想这时候你也是崩溃的。这时候日志的切割和保留就显得比较重要了
操作:
root@rpc0804:/etc/logrotate.d# cat /etc/logrotate.conf
......
include /etc/logrotate.d
......
root@rpc0804:/home/worker/mysql/log# cd /etc/logrotate.d/
root@rpc0804:/etc/logrotate.d# cat mysql-slow-logs
/home/worker/mysql/log/mysql-slow.log {
daily
dateext
compress
missingok
notifempty
sharedscripts
create 640 mysql mysql
postrotate
/bin/mysql -e 'select @@global.slow_query_log into @sq_log_save; set global slow_query_log=off; select sleep(5); FLUSH SLOW LOGS; select sleep(10); set global slow_query_log=@sq_log_save;&