自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

一款超級強大的慢SQL排查工具!

數(shù)據(jù)庫 SQL Server
在項目中我們會經(jīng)常遇到慢查詢,當(dāng)我們遇到慢查詢的時候一般都要開啟慢查詢?nèi)罩?,并且分析慢查詢?nèi)罩?,找到慢sql,然后用explain來分析

 [[389615]]

開啟慢查詢?nèi)罩?/h2>

在項目中我們會經(jīng)常遇到慢查詢,當(dāng)我們遇到慢查詢的時候一般都要開啟慢查詢?nèi)罩荆⑶曳治雎樵內(nèi)罩?,找到慢sql,然后用explain來分析

系統(tǒng)變量

MySQL和慢查詢相關(guān)的系統(tǒng)變量如下: 

 

執(zhí)行如下語句看是否啟用慢查詢?nèi)罩?,ON為啟用,OFF為沒有啟用 

  1. show variables like "%slow_query_log%" 

 

可以看到我的沒有啟用,可以通過如下兩種方式開啟慢查詢 

修改配置文件

修改配置文件my.ini,在[mysqld]段落中加入如下參數(shù) 

  1. [mysqld] 
  2. log_output='FILE,TABLE' 
  3. slow_query_log='ON' 
  4. long_query_time=0.001 

「需要重啟 MySQL 才可以生效,命令為 service mysqld restart」

設(shè)置全局變量

我在命令行中執(zhí)行如下2句打開慢查詢?nèi)罩?,設(shè)置超時時間為0.001s,并且將日志記錄到文件以及mysql.slow_log表中 

  1. set global slow_query_log = on
  2. set global log_output = 'FILE,TABLE'
  3. set global long_query_time = 0.001; 

「想要永久生效得到配置文件中配置,否則數(shù)據(jù)庫重啟后,這些配置失效」

分析慢查詢?nèi)罩?/h2>

因為mysql慢查詢?nèi)罩鞠喈?dāng)于是一個流水賬,并沒有匯總統(tǒng)計的功能,所以我們需要用一些工具來分析一下

mysqldumpslow

mysql內(nèi)置了mysqldumpslow這個工具來幫我們分析慢查詢?nèi)罩尽?nbsp;

 

常見用法

  1. # 取出使用最多的10條慢查詢 
  2. mysqldumpslow -s c -t 10 /var/run/mysqld/mysqld-slow.log 
  3.  
  4. # 取出查詢時間最慢的3條慢查詢 
  5. mysqldumpslow -s t -t 3 /var/run/mysqld/mysqld-slow.log  
  6.  
  7. # 得到按照時間排序的前10條里面含有左連接的查詢語句 
  8. mysqldumpslow -s t -t 10 -g “left join” /database/mysql/slow-log  

pt-query-digest

pt-query-digest是我用的最多的一個工具,功能非常強大,可以分析binlog、General log、slowlog,也可以通過show processlist或者通過tcpdump抓取的MySQL協(xié)議數(shù)據(jù)來進行分析。pt-query-digest是一個perl腳本,只需下載并賦權(quán)即可執(zhí)行

下載和賦權(quán) 

  1. wget www.percona.com/get/pt-query-digest 
  2. chmod u+x pt-query-digest 
  3. ln -s /opt/soft/pt-query-digest /usr/bin/pt-query-digest 

用法介紹 

  1. // 查看具體使用方法  
  2. pt-query-digest --help 
  3. // 使用格式 
  4. pt-query-digest [OPTIONS] [FILES] [DSN] 

「常用OPTIONS」 

  1. --create-review-table  當(dāng)使用--review參數(shù)把分析結(jié)果輸出到表中時,如果沒有表就自動創(chuàng)建。 
  2. --create-history-table  當(dāng)使用--history參數(shù)把分析結(jié)果輸出到表中時,如果沒有表就自動創(chuàng)建。 
  3. --filter  對輸入的慢查詢按指定的字符串進行匹配過濾后再進行分析 
  4. --limit限制輸出結(jié)果百分比或數(shù)量,默認值是20,即將最慢的20條語句輸出,如果是50%則按總響應(yīng)時間占比從大到小排序,輸出到總和達到50%位置截止。 
  5. --host  mysql服務(wù)器地址 
  6. --user  mysql用戶名 
  7. --password  mysql用戶密碼 
  8. --history 將分析結(jié)果保存到表中,分析結(jié)果比較詳細,下次再使用--history時,如果存在相同的語句,且查詢所在的時間區(qū)間和歷史表中的不同,則會記錄到數(shù)據(jù)表中,可以通過查詢同一CHECKSUM來比較某類型查詢的歷史變化。 
  9. --review 將分析結(jié)果保存到表中,這個分析只是對查詢條件進行參數(shù)化,一個類型的查詢一條記錄,比較簡單。當(dāng)下次使用--review時,如果存在相同的語句分析,就不會記錄到數(shù)據(jù)表中。 
  10. --output 分析結(jié)果輸出類型,值可以是report(標準分析報告)、slowlog(Mysql slow log)、json、json-anon,一般使用report,以便于閱讀。 
  11. --since 從什么時間開始分析,值為字符串,可以是指定的某個”yyyy-mm-dd [hh:mm:ss]”格式的時間點,也可以是簡單的一個時間值:s(秒)、h(小時)、m(分鐘)、d(天),如12h就表示從12小時前開始統(tǒng)計。 
  12. --until 截止時間,配合—since可以分析一段時間內(nèi)的慢查詢。 

「常用DSN」 

  1. A    指定字符集 
  2. D    指定連接的數(shù)據(jù)庫 
  3. P    連接數(shù)據(jù)庫端口 
  4. S    連接Socket file 
  5. h    連接數(shù)據(jù)庫主機名 
  6. p    連接數(shù)據(jù)庫的密碼 
  7. t    使用--review或--history時把數(shù)據(jù)存儲到哪張表里 
  8. u    連接數(shù)據(jù)庫用戶名 

DSN使用key=value的形式配置;多個DSN使用,分隔

「使用示例」 

  1. # 展示slow.log中最慢的查詢的報表 
  2. pt-query-digest slow.log 
  3.  
  4. # 分析最近12小時內(nèi)的查詢 
  5. pt-query-digest --since=12h slow.log 
  6.  
  7. # 分析指定范圍內(nèi)的查詢 
  8. pt-query-digest slow.log --since '2020-06-20 00:00:00' --until '2020-06-25 00:00:00' 
  9.  
  10. # 把slow.log中查詢保存到query_history表 
  11. pt-query-digest --user=root --password=root123 --review h=localhost,D=test,t=query_history --create-review-table slow.log 
  12.  
  13. # 連上localhost,并讀取processlist,輸出到slowlog 
  14. pt-query-digest --processlist h=localhost --user=root --password=root123 --interval=0.01 --output slowlog 
  15.  
  16. # 利用tcpdump獲取MySQL協(xié)議數(shù)據(jù),然后產(chǎn)生最慢查詢的報表 
  17. # tcpdump使用說明:https://blog.csdn.net/chinaltx/article/details/87469933 
  18. tcpdump -s 65535 -x -nn -q -tttt -i any -c 1000 port 3306 > mysql.tcp.txt 
  19. pt-query-digest --type tcpdump mysql.tcp.txt 
  20.  
  21. # 分析binlog 
  22. mysqlbinlog mysql-bin.000093 > mysql-bin000093.sql 
  23. pt-query-digest  --type=binlog mysql-bin000093.sql 
  24.  
  25. # 分析general log 
  26. pt-query-digest  --type=genlog  localhost.log 

用法實戰(zhàn)

「編寫存儲過程批量造數(shù)據(jù)」

在實際工作中沒有測試性能,我們經(jīng)常需要改造大批量的數(shù)據(jù),手動插入是不太可能的,這時候就得用到存儲過程了 

  1. CREATE TABLE `kf_user_info` ( 
  2.   `id` int(11) NOT NULL COMMENT '用戶id'
  3.   `gid` int(11) NOT NULL COMMENT '客服組id'
  4.   `namevarchar(25) NOT NULL COMMENT '客服名字' 
  5. ) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='客戶信息表'

如何定義一個存儲過程呢? 

  1. CREATE PROCEDURE 存儲過程名稱 ([參數(shù)列表]) 
  2. BEGIN 
  3.     需要執(zhí)行的語句 
  4. END 

舉個例子,插入id為1-100000的100000條數(shù)據(jù)

用Navicat執(zhí)行 

  1. -- 刪除之前定義的 
  2. DROP PROCEDURE IF EXISTS create_kf; 
  3.  
  4. -- 開始定義 
  5. CREATE PROCEDURE create_kf(IN loop_times INT)  
  6. BEGIN 
  7.  DECLARE var INT
  8.  SET var = 1; 
  9.  WHILE var < loop_times DO     
  10.   INSERT INTO kf_user_info (`id`,`gid`,`name`)  
  11.   VALUES (var, 1000, var); 
  12.   SET var = var + 1; 
  13.  END WHILE;  
  14. END
  15.  
  16. -- 調(diào)用 
  17. call create_kf(100000); 

存儲過程的三種參數(shù)類型 

用MySQL執(zhí)行

得用DELIMITER 定義新的結(jié)束符,因為默認情況下SQL采用(;)作為結(jié)束符,這樣當(dāng)存儲過程中的每一句SQL結(jié)束之后,采用(;)作為結(jié)束符,就相當(dāng)于告訴MySQL可以執(zhí)行這一句了。但是存儲過程是一個整體,我們不希望SQL逐條執(zhí)行,而是采用存儲過程整段執(zhí)行的方式,因此我們就需要定義新的DELIMITER ,新的結(jié)束符可以用(//)或者($$)

因為上面的代碼應(yīng)該就改為如下這種方式 

  1. DELIMITER // 
  2. CREATE PROCEDURE create_kf_kfGroup(IN loop_times INT)   
  3. BEGIN   
  4.  DECLARE var INT
  5.  SET var = 1; 
  6.  WHILE var <= loop_times DO     
  7.   INSERT INTO kf_user_info (`id`,`gid`,`name`)  
  8.   VALUES (var, 1000, var); 
  9.   SET var = var + 1; 
  10.  END WHILE;   
  11. END // 
  12. DELIMITER ;  

查詢已經(jīng)定義的存儲過程 

  1. show procedure status; 

「開始執(zhí)行慢sql」 

  1. select * from kf_user_info where id = 9999; 
  2. select * from kf_user_info where id = 99999; 
  3. update kf_user_info set gid = 2000 where id = 8888; 
  4. update kf_user_info set gid = 2000 where id = 88888; 

可以執(zhí)行如下sql查看慢sql的相關(guān)信息。 

  1. SELECT * FROM mysql.slow_log order by start_time desc

查看一下慢日志存儲位置 

  1. show variables like "slow_query_log_file" 

 

  1. pt-query-digest /var/lib/mysql/VM-0-14-centos-slow.log 

執(zhí)行后的文件如下: 

 

  1. # Profile 
  2. # Rank Query ID                            Response time Calls R/Call V/M  
  3. # ==== =================================== ============= ===== ====== ==== 
  4. #    1 0xE2566F6154AFF41948FE497E53631B43   0.1480 56.1%     4 0.0370  0.00 UPDATE kf_user_info 
  5. #    2 0x2DFBC6DBF0D68EF2EC2AE954DC37A1A4   0.1109 42.1%     4 0.0277  0.00 SELECT kf_user_info 
  6. # MISC 0xMISC                               0.0047  1.8%     2 0.0024   0.0 <2 ITEMS> 

從最上面的統(tǒng)計sql中就可以看到執(zhí)行慢的sql

可以看到響應(yīng)時間,執(zhí)行次數(shù),每次執(zhí)行耗時(單位秒),執(zhí)行的sql

下面就是各個慢sql的詳細分析,比如,執(zhí)行時間,獲取鎖的時間,執(zhí)行時間分布,所在的表等信息

「不由得感嘆一聲,真是神器,查看慢sql超級方便」

最后說一個我遇到的一個有意思的問題,有一段時間線上的接口特別慢,但是我查日志發(fā)現(xiàn)sql執(zhí)行的很快,難道是網(wǎng)絡(luò)的問題?

為了確定是否是網(wǎng)絡(luò)的問題,我就用攔截器看了一下接口的執(zhí)行時間,發(fā)現(xiàn)耗時很長,考慮到方法加了事務(wù),難道是事務(wù)提交很慢?

于是我用pt-query-digest統(tǒng)計了一下1分鐘左右的慢日志,發(fā)現(xiàn)事務(wù)提交的次很多,但是每次提交事務(wù)的平均時長是1.4s左右,果然是事務(wù)提交很慢。 

 

 

責(zé)任編輯:華軒 來源: Java識堂
相關(guān)推薦

2021-07-09 10:14:05

IP工具命令

2017-02-27 17:42:26

LinuxCPU工具

2023-10-10 07:08:42

2020-12-15 07:54:40

工具Hutoolgithub

2020-12-15 15:08:17

工具Java線程

2021-04-09 09:09:35

網(wǎng)絡(luò)工具netwox Python

2022-09-30 13:09:32

VSLookVS Code工具

2010-12-09 10:54:32

2021-10-10 12:17:06

Weakpass在線字典生成器安全工具

2021-11-01 05:53:08

Doldrums逆向工程分析工具安全工具

2021-09-14 15:01:31

Pstf安全工具指紋框架

2022-01-24 16:17:26

htop工具Linux

2021-10-19 06:37:21

安全工具Qlog安全日志工具

2023-10-08 07:51:07

HInvoke項目函數(shù)

2016-02-15 11:44:23

源碼開源項目watch

2011-07-27 09:54:24

2019-03-19 15:25:47

toplip加密工具開源

2018-12-10 10:30:40

阿里Linux命令

2021-12-02 18:14:37

PortBender定向工具安全工具

2020-12-08 10:05:26

應(yīng)用視頻音頻
點贊
收藏

51CTO技術(shù)棧公眾號