python mysql binlog_python写的分析mysql binlog日志工具

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值