zoukankan      html  css  js  c++  java
  • python写的分析mysql binlog日志工具

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

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    #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]

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

    本文出自 “王伟” 博客,请务必保留此出处http://wangwei007.blog.51cto.com/68019/1306940

  • 相关阅读:
    springmvc和struts2的区别(转)
    springmvc和struts2的区别
    sql优化(转)
    java反射机制
    阿里云产品
    vscode 插件推荐
    测试JS方法运行时间
    基于VUE2.0的分页插件(很好用,很简单)
    【软件测试】测试管理工具----禅道
    Vue.js中用webpack合并打包多个组件并实现按需加载
  • 原文地址:https://www.cnblogs.com/wajika/p/6235639.html
Copyright © 2011-2022 走看看