温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

使用logrotate工具切割MySQL日志与慢日志分析发送到邮箱

发布时间:2020-05-30 22:05:43 来源:网络 阅读:5433 作者:对唔住 栏目:MySQL数据库

1.安装logrotate与percona-toolkit
yum install logrotate -y
yum install https://www.percona.com/redir/downloads/percona-release/redhat/percona-release-0.1-4.noarch.rpm
yum install percona-toolkit
2.创建logrotate配置文件
在/etc/logrotate.d/目录下新建3306_error文件

vim /etc/ogrotate.d/3306_error         
/data/mysql/3306/error.log {              #写明自己的日志文件具体位置
    monthly                                            #每月切割一次
    rotate 13                                         #保存13个日志并轮转,13个月正好能够与去年次月同比比较
    dateext                                            #切割出来的文件以 “原文件名+20171230”类似的格式命名
    compress                                       #使用gzip压缩切割出来的文件
    delaycompress                              #最近一次分割出来的文件不压缩(方便分析)
    missingok                                      #在日志轮循期间,任何错误将被忽略,例如“文件无法找到”之类的错误。
    notifempty                                     #如果上次分割后未产生新日志,则不再次分割
postrotate
   mysql --login-path=3306 -e 'flush error logs;'       #切割之后执行的操作,MySQL需要执行这个命令刷新日志句柄
endscript
}

在/etc/logrotate.d/目录下新建3306_slow文件

vim /etc/logrotate.d/3306_error 
/data/mysql/3306/slow.log {
    daily
    rotate 13
    dateext    
    compress
    delaycompress
    missingok
    notifempty
postrotate
   mysql --login-path=3306 -e 'flush slow logs;'
     #使用pt-query-digest工具分析切割的慢日志并发送到邮箱
   pt-query-digest  /data/mysql/3306/slow.log-`date +%Y%m%d`|mail -s '4S_slow_log' psyduck007@outlook.com
endscript
}

3.手动切割日志
logrotate -f /etc/logrotate.d/3306_error

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI