为了账号安全,请及时绑定邮箱和手机立即绑定

python写的分析mysql binlog日志工具

标签:
MySQL


因为数据库增删改突然暴增,需要查询是那些表的操作特别频繁,写了一个用来分析bin-log的小工具,找出增删改查的表,并按照操作次数降序排列,以下是代码:

#for mysql5.5 binlog

import os,sys

#python binlog.py binglog-0001 '2013-07-01 00:00:00' '2013-07-02 00:00:00'

def log_w(type,text):

    logfile = "%s.txt" % (type,text)

    #now = time.strftime("%Y-%m-%d %H:%M:%S")

    tt = str(text) + "\n"

    f = open(logfile,'a+')

    f.write(tt)

    f.close()

logname = sys.argv[1]

start_time = sys.argv[2]

end_time = sys.argv[3]

comn = "/usr/bin/mysqlbinlog --start-datetime='%s' --stop-datetime='%s' %s" % (start_time,end_time,logname)

aa=os.popen(comn).readlines()

mylist=[]

for a in aa:

    if ('UPDATE' in a):

            update = ' '.join(a.split()[:2])

            mylist.append(update)

    if ('INSERT INTO' in a):

            update = ' '.join(a.split()[:3]).replace("INTO ","")

            mylist.append(update)

    if ('DELETE from' in a):

            update = ' '.join(a.split()[:3]).replace("from ","")

            mylist.append(update)

mylist.sort()

bb = list(set(mylist))

bb.sort()

cc = []

for item in bb:

        cc.append([mylist.count(item),(item)])

cc.sort()

cc.reverse()

for i in cc:

        print str(i[0])+'\t'+i[1]

spacer.gifspacer.gif执行结果如下:165939295.jpg

©著作权归作者所有:来自51CTO博客作者AIOPS_DBA的原创作品,如需转载,请注明出处,否则将追究法律责任

工具日志分析MySQL


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消