因为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) + "
"
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])+" "+i[1]执行结果如下:
相关阅读:如何安全删除MySQL下的binlog日志 http://www.linuxidc.com/Linux/2013-06/86527.htmMySQL--binlog日志恢复数据 http://www.linuxidc.com/Linux/2013-04/82368.htmMySQL删除binlog日志及日志恢复数据的方法 http://www.linuxidc.com/Linux/2012-12/77072.htmMySQL binlog三种格式介绍及分析 http://www.linuxidc.com/Linux/2012-11/74359.htmMySQL 利用binlog增量备份+还原实例 http://www.linuxidc.com/Linux/2012-09/70815.htmMySQL删除binlog日志及日志恢复数据 http://www.linuxidc.com/Linux/2012-08/67594.htmMySQL binlog预分配的实现和性能 http://www.linuxidc.com/Linux/2012-03/57203.htmMariaDB 和 MySQL 比较PostgreSQL的行转列应用相关资讯 MySQL binlog
- MySQL binlog中的事件类型 (08月19日)
- MySQL binlog 安全删除 (03月30日)
- MySQL 5.6.12切换binlog二进制日志 (01月02日)
| - MySQL数据丢失后利用binlog恢复有 (04月18日)
- 关于使用MySQL binlog对数据进行恢 (01月24日)
- MySQL binlog 组提交与 XA(两阶段 (11/08/2015 10:16:03)
|
本文评论 查看全部评论 (0)