小标
2018-08-28
来源 :
阅读 1763
评论 0
摘要:本文主要向大家介绍了VC编程之vc-mysql-sniffer统计MySQL的SQL分布,通过具体的内容向大家展示,希望对大家学习VC编程有所帮助。
本文主要向大家介绍了VC编程之vc-mysql-sniffer统计MySQL的SQL分布,通过具体的内容向大家展示,希望对大家学习VC编程有所帮助。
有时候我们需要统计线上的SQL执行情况,比如想知道哪条SQL执行最频繁,我们可以开启general_log,然后进行统计,但是general_log开启非常损耗性能,那么我们可以使用vc-mysql-sniffer来代替,改工具是编译好的二进制,下载即可使用。下载地址:
https://www.vividcortex.com/resources/network-analyzer-for-mysql
我这里修改了网上的一个脚本,分析vc-mysql-sniffer抓取到的结果统计频繁执行的SQL。
#!/usr/bin/python
#coding:utf8
# python analysis-vc-log.py 3315 | sort | uniq -c | sort -nr |head -n 10
import re
import sys
import os
import commands
vc_sniffer_time=5
port=sys.argv[1]
vc_cmd=""" /usr/bin/timeout %s /data/software/vc-mysql-sniffer -binding="[::]:%s" > /tmp/tmp_vc_mysql_%s.txt """ % (vc_sniffer_time,port,port)
outtext = commands.getoutput(vc_cmd)
cmd=""" grep -Ev ‘# Time:|# User@Host‘ /tmp/tmp_vc_mysql_%s.txt |sed ‘s/# Query_time.*/myxxxxx/g‘ |awk BEGIN{RS=EOF}‘{gsub(/\\n/," ");print}‘|awk BEGIN{RS=EOF}‘{gsub(/myxxxxx/,"\\n");print}‘ >/tmp/vc_mysql_%s.tx
t""" % (port,port)
outtext = commands.getoutput(cmd)
file="/tmp/vc_mysql_%s.txt" % (port)
logFo = open(file)
for line in logFo:
line = re.sub(r"\n","",line)
lineMatch = re.match(r".*",line)
if lineMatch:
lineTmp = lineMatch.group(0)
# remove extra space
lineTmp = re.sub(r"\s+", " ",lineTmp)
# replace values (value) to values (x)
lineTmp = re.sub(r"values\s*\(.*?\)", "values (x)",lineTmp)
# replace filed = ‘value‘ to filed = ‘x‘
lineTmp = re.sub(r"(=|>|<|>=|<=)\s*(‘|\").*?\2","\\1 replace="" filed="x<br/" to="" linetmp="re.sub(r"(=|">|<|>=|<=)\s*[0-9]+","\\1 x",lineTmp)
# replace like ‘value‘ to like ‘x‘
lineTmp = re.sub(r"like\s+(‘|\").*?\1","like ‘x‘",lineTmp)
# replace in (value) to in (x)
lineTmp = re.sub(r"in\s+\(.*?\)","in (x)",lineTmp)
# replace limit x,y to limit
lineTmp = re.sub(r"limit.*","limit",lineTmp)
print lineTmp
logFo.close()
python analysis-vc-log.py 3310 | sort | uniq -c | sort -nr |head -n 10
抓取mysql 3310端口,统计执行最频繁的10条SQL。结果我这里就不贴上来了。有兴趣的同学自己测试。
本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注职坐标编程语言VC/MFC频道!
喜欢 | 0
不喜欢 | 0
您输入的评论内容中包含违禁敏感词
我知道了

请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号