欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的詳細(xì)介紹

 更新時間:2020年07月13日 17:27:35   作者:wdw王大為  
這篇文章主要介紹了關(guān)于Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的詳細(xì)介紹,Anemometer 是一個圖形化顯示MySQL慢日志的工具,Anemometer可以很輕松的幫你去分析慢查詢?nèi)罩?,讓你很容易就能找到哪些SQL需要優(yōu)化。感興趣可以來了解一下

介紹:Anemometer 是一個圖形化顯示MySQL慢日志的工具。結(jié)合pt-query-digest,Anemometer可以很輕松的幫你去分析慢查詢?nèi)罩荆屇愫苋菀拙湍苷业侥男㏒QL需要優(yōu)化

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

官方網(wǎng)站:https://github.com/box/Anemometer

環(huán)境概況

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

需要安裝的步驟如下:

1.percona-toolkit工具的安裝

2.php web環(huán)境的搭建安裝

3.Anemometer并配置

4.導(dǎo)入慢查詢?nèi)罩?/p>

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

6.其他相關(guān)和問題解決

0. 整體的架構(gòu)


1. percona-toolkit工具的安裝

安裝目的:pt-query-digest是percona-toolkit里面一個工具,其作用就是分析慢查詢?nèi)罩?,將MySQL慢查詢?nèi)罩具M(jìn)行統(tǒng)計并友好的顯示出來

下載地址: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二進(jìn)制)

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環(huán)境的搭建

安裝目的:Anemometer需要依賴
LAMP環(huán)境LAMP環(huán)境的安裝:
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、修改時區(qū),vim /etc/php.ini,修改為 date.timezone = PRC

LAMP環(huán)境的啟動:
1、啟動,systemctl start httpd
2、關(guān)閉,systemctl stop httpd
3、重啟,systemctl restart httpd
4、查看,systemctl status httpd

3. 安裝Anemometer并配置

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

4、修改配置文件指向數(shù)據(jù)源文件,vim conf/datasource_localhost.inc.php,當(dāng)然也可以直接vim conf/config.inc.php

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

4. 導(dǎo)入慢查詢?nèi)罩?/strong>

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主機對應(yīng)ip地址)


6、其他相關(guān)和問題解決

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


以上就是關(guān)于Anemometer圖形化顯示MySQL慢日志的工具搭建及使用的詳細(xì)介紹的詳細(xì)內(nèi)容,更多關(guān)于Anemometer圖形化顯示MySQL慢日志的工具搭建的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • PHP實現(xiàn)對數(shù)組分頁處理實例詳解

    PHP實現(xiàn)對數(shù)組分頁處理實例詳解

    這篇文章主要介紹了PHP實現(xiàn)對數(shù)組分頁處理,結(jié)合實例形式分析了php封裝的數(shù)組分頁類定義與使用技巧,需要的朋友可以參考下
    2017-02-02
  • PHP 單引號與雙引號的區(qū)別

    PHP 單引號與雙引號的區(qū)別

    看好多代碼有時候用單引號或雙引號實現(xiàn)包含字符串的內(nèi)容,其實簡單個概括下雙引號中的變量可以解析,單引號就是絕對的字符串。
    2009-11-11
  • php數(shù)組對百萬數(shù)據(jù)進(jìn)行排除重復(fù)數(shù)據(jù)的實現(xiàn)代碼

    php數(shù)組對百萬數(shù)據(jù)進(jìn)行排除重復(fù)數(shù)據(jù)的實現(xiàn)代碼

    在平時的工作中,經(jīng)常接到要對網(wǎng)站的會員進(jìn)行站內(nèi)信、手機短信、email進(jìn)行群發(fā)信息的通知,用戶列表一般由別的同事提供,當(dāng)中難免會有重復(fù),為了避免重復(fù)發(fā)送,所以我在進(jìn)行發(fā)送信息前要對他們提供的用戶列表進(jìn)行排重,下面我以uid列表來講講我是如何利用php數(shù)組進(jìn)行排重的。
    2010-06-06
  • Laravel中使用阿里云OSS Composer包分享

    Laravel中使用阿里云OSS Composer包分享

    這篇文章主要介紹了Laravel中使用阿里云OSS Composer包分享,本文講解其使用方法,文件下載請前往文件中的github地址,需要的朋友可以參考下
    2015-02-02
  • 解析php dirname()與__FILE__常量的應(yīng)用

    解析php dirname()與__FILE__常量的應(yīng)用

    本篇文章是對php中的dirname()與__FILE__常量的應(yīng)用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • PHP測試成功的郵件發(fā)送案例

    PHP測試成功的郵件發(fā)送案例

    這篇文章主要介紹了一個測試成功的PHP郵件發(fā)送案例,需要的朋友可以參考下
    2015-10-10
  • PHP 簡單日歷實現(xiàn)代碼

    PHP 簡單日歷實現(xiàn)代碼

    寫文件系統(tǒng)的時候看中了個國外的HTML模板...上面有個日歷,就想用PHP寫出來...
    2009-10-10
  • PHP使用TCPDF處理pdf

    PHP使用TCPDF處理pdf

    TCPDF是一個開源的PHP庫,用于創(chuàng)建和處理PDF文件,這篇文章主要為大家詳細(xì)介紹了PHP如何使用TCPDF進(jìn)行pdf的相關(guān)操作,需要的小伙伴可以參考下
    2023-12-12
  • php為字符串前后添加指定數(shù)量字符的方法

    php為字符串前后添加指定數(shù)量字符的方法

    這篇文章主要介紹了php為字符串前后添加指定數(shù)量字符的方法,涉及php操作字符串的相關(guān)技巧,非常具有實用價值,需要的朋友可以參考下
    2015-05-05
  • 完美解決PHP中文亂碼

    完美解決PHP中文亂碼

    PHP中文亂碼一般是字符集問題,編碼主要有下面幾個問題。
    2009-11-11

最新評論