慢查询sql集中到数据库中进行集中管理脚本

#!/bin/bash
###slow_to_archery
#*/2 * * * * sh /home/work/bin/analysis_slow_query.sh 2>&1

DIR="$( cd "$( dirname "$0"  )" && pwd  )"
cd $DIR

#配置数据库的连接地址
monitor_db_host="192.168.5.244"
monitor_db_port=3306
monitor_db_user="root"
monitor_db_password="XxvTDtoPfLnA9bls"
monitor_db_database="archery"

#实例慢日志位置
slowquery_file="/home/mysql/slow.log"
pt_query_digest="/usr/bin/pt-query-digest"

#实例连接信息
hostname="192.168.0.43:3306" # 和archery实例配置内容保持一致,用于archery做筛选

#获取上次分析时间,初始化时请删除last_analysis_time_$hostname文件,可分析全部日志数据
if [ -s last_analysis_time_$hostname ]; then
    last_analysis_time=`cat last_analysis_time_$hostname`
else
    last_analysis_time='1000-01-01 00:00:00'
fi

#收集日志
#RDS需要增加--no-version-check选项
$pt_query_digest \
--user=$monitor_db_user --password=$monitor_db_password --port=$monitor_db_port \
--review h=$monitor_db_host,D=$monitor_db_database,t=mysql_slow_query_review  \
--history h=$monitor_db_host,D=$monitor_db_database,t=mysql_slow_query_review_history  \
--no-report --limit=100% --charset=utf8 \
--since "$last_analysis_time" \
--filter "\$event->{Bytes} = length(\$event->{arg}) and \$event->{hostname}=\"$hostname\"  and \$event->{client}=\$event->{ip} " \
$slowquery_file > /tmp/analysis_slow_query.log

echo `date +"%Y-%m-%d %H:%M:%S"`>last_analysis_time_$hostname

引用 archery中的慢sql收集脚本

posted @ 2019-05-07 13:47  TT-小白龙  阅读(274)  评论(0编辑  收藏  举报