继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

python写的分析mysql binlog日志工具

largeQ
关注TA
已关注
手记 989
粉丝 92
获赞 585


因为数据库增删改突然暴增,需要查询是那些表的操作特别频繁,写了一个用来分析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


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP