站長資訊網
        最全最豐富的資訊網站

        Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的實例解析

        Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的實例解析

        介紹:Anemometer 是一個圖形化顯示MySQL慢日志的工具。結合pt-query-digest,Anemometer可以很輕松的幫你去分析慢查詢日志,讓你很容易就能找到哪些SQL需要優化

        This is the Box Anemometer, the MySQL Slow Query Monitor. This tool is used to analyze slow query logs collected from MySQL instances to identify problematic queries

        相關學習推薦:PHP編程從入門到精通

        環境概況

        以寫此文章時 percona-toolkit最新的版本3.0.10為例
        mysql數據庫對應版本為5.7.21,二進制安裝
        http和php均是系統CentOS Linux release 7.4.1708 (Core)自帶版本

        需要安裝的步驟如下:

        1.percona-toolkit工具的安裝

        2.php web環境的搭建安裝

        3.Anemometer并配置

        4.導入慢查詢日志

        5.訪問界面,查看慢查詢

        6.其他相關和問題解決

        0. 整體的架構

        Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的實例解析

        1. percona-toolkit工具的安裝

        安裝目的:pt-query-digest是percona-toolkit里面一個工具,其作用就是分析慢查詢日志,將MySQL慢查詢日志進行統計并友好的顯示出來

        下載地址:https://www.percona.com/downloads/percona-toolkit/

        安裝方式(rpm):

        1、下載包,wget https://www.percona.com/downloads/percona-toolkit/3.0.10/binary/redhat/7/x86_64/percona-toolkit-3.0.10-1.el7.x86_64.rpm

        2、安裝依賴,yum install perl-DBI perl-DBD-MySQL perl-IO-Socket-SSL perl-Digest-MD5 -y

        3、正式安裝,rpm -ivh percona-toolkit-3.0.10-1.el7.x86_64.rpm

        4、安裝完畢驗證,pt-query-digest --version pt-query-digest 3.0.10

        安裝方式(tar二進制)

        1、下載包,wget https://www.percona.com/downloads/percona-toolkit/3.0.10/binary/tarball/percona-toolkit-3.0.10_x86_64.tar.gz

        2、安裝依賴,yum install perl-DBI perl-DBD-MySQL perl-IO-Socket-SSL perl-Digest-MD5 -y

        3、解壓包,tar xf percona-toolkit-3.0.10_x86_64.tar.gz

        4、直接使用工具, ./percona-toolkit-3.0.10/bin/pt-query-digest --version
        pt-query-digest 3.0.10

        2. php web環境的搭建

        安裝目的:Anemometer需要依賴
        LAMP環境LAMP環境的安裝:
        1、安裝apache,yum install httpd httpd-devel -y
        2、安裝php,yum install php php-mysql php-common php-bcmath php-dba php-cli php-gd php-mbstring php-mcrypt php-devel php-xml php-pdo -y
        3、修改時區,vim /etc/php.ini,修改為 date.timezone = PRC

        LAMP環境的啟動:
        1、啟動,systemctl start httpd
        2、關閉,systemctl stop httpd
        3、重啟,systemctl restart httpd
        4、查看,systemctl status httpd

        3. 安裝Anemometer并配置

        1、下載安裝:
        安裝目的:安裝Anemometer應用
        下載地址:https://github.com/box/Anemometer
        下載包:git clone https://github.com/box/Anemometer.git
        移動到對應路徑:mv Anemometer /var/www/html/anemometer
        2、目標慢查詢數據庫上需要授予Anemometer主機對應的權限
        1、目的,用于分析目標慢查詢數據庫explain執行計劃
        2、授權,grant select on *.* to 'anemometer'@'$ip' identified by '123456';flush privileges;($ip為Anemometer主機對應ip地址)
        3、修改配置文件增加explain讀取用戶密碼信息 cp conf/sample.config.inc.php conf/config.inc.php vim conf/config.inc.php\

        Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的實例解析

        4、修改配置文件指向數據源文件,vim conf/datasource_localhost.inc.php,當然也可以直接vim conf/config.inc.php

        Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的實例解析

        5、初始化數據源的數據庫表的配置,mysql -uroot -p123456 -h127.0.0.1 -P5700 < install.sql,每個datasource源頭可以對應不同的數據庫database(修改install.sql的內容)

        Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的實例解析

        4. 導入慢查詢日志

        1、慢查詢主機推送格式

        For pt-query-digest version < 2.2 $ pt-query-digest --user=anemometer --password=superSecurePass  --review h=db.example.com,D=slow_query_log,t=global_query_review  --review-history h=db.example.com,D=slow_query_log,t=global_query_review_history  --no-report --limit=0%   --filter=" $event->{Bytes} = length($event->{arg}) and $event->{hostname}="$HOSTNAME""   /var/lib/mysql/db.example.com-slow.log  For pt-query-digest version >= 2.2 $ pt-query-digest --user=anemometer --password=superSecurePass  --review h=db.example.com,D=slow_query_log,t=global_query_review  --history h=db.example.com,D=slow_query_log,t=global_query_review_history  --no-report --limit=0%   --filter=" $event->{Bytes} = length($event->{arg}) and $event->{hostname}="$HOSTNAME""   /var/lib/mysql/db.example.com-slow.log

        2、慢查詢主機推動腳本示例

        #config anemometer server, the purpose is to push slow query to the remote anemometer server and store it. anemometer_host="127.0.0.1" anemometer_user="root" anemometer_password="123456" anemometer_port=5700 anemometer_db="slow_query_log"  #config mysql server, the purpose is to get the path of the slow query log. mysql_client="/usr/local/mysql-5.7.21/bin/mysql" mysql_user="root" mysql_password="123456" mysql_socket="/tmp/mysql_5700.sock" mysql_port=5700  #config slowqury dir to cd, and then delete the expired slow query file. slowquery_dir="/data/mysql_$mysql_port/"  #get the path of the slow query log. slowquery_file=`$mysql_client -u$mysql_user -p$mysql_password -S $mysql_socket -e "show variables like 'slow_query_log_file'"|grep log|awk '{print $2}'` pt_query_digest="/data/percona-toolkit-3.0.10/bin/pt-query-digest"  #collect mysql slowquery log into lepus database. $pt_query_digest --user=$anemometer_user --password=$anemometer_password --port=$anemometer_port --review h=$anemometer_host,D=$anemometer_db,t=global_query_review --history h=$anemometer_host,D=$anemometer_db,t=global_query_review_history --no-report --limit=0% --filter=" $event->{Bytes} = length($event->{arg}) and $event->{hostname}="$HOSTNAME:$mysql_port"" $slowquery_file  #generate a new slow query log, the below is generate a new slow file per hour. tmp_log=`$mysql_client -u$mysql_user -p$mysql_password -S $mysql_socket -e "select concat('$slowquery_dir','slowquery_',date_format(now(),'%Y%m%d%H'),'.log');"|grep log|sed -n -e '2p'`  #use new slow file to config mysql slowquery $mysql_client -u$mysql_user -p$mysql_password -S $mysql_socket -e "set global slow_query_log = 0;set global slow_query_log_file = '$tmp_log';" $mysql_client -u$mysql_user -p$mysql_password -S $mysql_socket -e "set global slow_query_log = 1; "  #delete slow query file before 2 days cd $slowquery_dir /usr/bin/find ./ -name 'slowquery_*.log' -mtime +2|xargs rm -rf ;  ####END####

        5. 訪問界面,查看慢查詢

        http://$ip/anemometer/ ($ip為Anemometer主機對應ip地址)

        Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的實例解析

        Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的實例解析

        Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的實例解析

        6、其他相關和問題解決

        1、對于anemometer的主機上,需要進行慢查詢主機hostname和ip的映射(修改/etc/hosts進行配置),目的在于慢查詢explain執行計劃的目標主機解析
        #collect mysql slowquery log into lepus database步驟中,$HOSTNAME:$mysql_port
        數據庫存取的格式,hostname_max類似這種,cnwangdawei:5700
        2、中文亂碼的問題,在#collect mysql slowquery log into lepus database步驟中添加 –charset=utf8
        3、慢查詢主機數據庫是5.7版本的數據庫,可能出現界面ts_cnt不顯示,替換percona toolkit為新版本,2.x.x —–> 3.x.x
        4、表結構和狀態字符集顯示亂碼,添加mysqli的字符集設定,vim /var/www/html/anemometer/lib/QueryExplain.php
        新增(194行后增加),$this->mysqli->query("set names utf8");

        Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的實例解析

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产精品久久久久jk制服| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 自拍偷自拍亚洲精品情侣| 免费精品一区二区三区第35| 无码日韩人妻精品久久蜜桃 | 亚洲精品国产福利一二区| 国产精品极品| 久久这里只有精品久久| 国产精品一区二区av| 老司机性色福利精品视频| 亚洲精品麻豆av| 人妻偷人精品成人AV| 国产一区二区精品尤物| 91精品国产高清久久久久久国产嫩草| 国产精品999| 国产亚洲精品资源在线26u| 亚洲日韩精品A∨片无码| 少妇亚洲免费精品| 久久精品中文字幕有码| 国产精品欧美亚洲韩国日本久久 | 国产精品久久久福利| 国精品无码一区二区三区左线| 亚洲色精品88色婷婷七月丁香| 亚洲韩精品欧美一区二区三区| 欧美成人精品欧美一级乱黄码| 国产精品无码国模私拍视频| 成人国产一区二区三区精品| 麻豆精品不卡国产免费看| 成人精品视频在线观看| 国产成人久久精品区一区二区| 99久久精品费精品国产一区二区 | 国产精品免费精品自在线观看| 国产精品熟女一区二区| 久久er99热精品一区二区| 久久精品亚洲日本波多野结衣| 久久久无码人妻精品无码| 久久久久无码精品国产不卡| 久久精品国产亚洲77777| 国内精品伊人久久久久av一坑 | 97久久国产亚洲精品超碰热| 久久99国产乱子伦精品免费|